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(57) Abstract: A MIMO system supports multiple spatial multiplexing modes for 
improved performance and greater flexibility. These modes may include (1) a sin- 
gle-user steered mode that transmits multiple data streams on orthogonal spatial 
channels to a single receiver, (2) a single-user non- steered mode that transmits mul- 
tiple data streams from multiple antennas to a single receiver without spatial pro- 
cessing at a transmitter, (3) a multi-user steered mode that transmits multiple data 
streams simultaneously to multiple receivers with spatial processing at a transmit- 
ter, and (4) a multi-user non-steered mode that transmits multiple data streams from 
multiple antennas (co- located or non co-located) without spatial processing at the 
transmitters) to receivers) having multiple antennas. For each set of user termi- 
nal(s) selected for data transmission on the downlink and/or uplink, a spatial multi- 
plexing mode is selected for the user terminal set from among the multiple spatial 
multiplexing modes supported by the system. 
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RANDOM ACCESS FOR WIRELESS MULTIPLE-ACCESS 
COMMUNICATION SYSTEMS 

Claim of Priority under 35 ILS.C. §119 

[0001] This application claims the benefit of U.S. Provisional Application Serial No. 

60/421,309, entitled "MEMO WLAN System," filed on October 25, 2002, assigned to 
the assignee of the present application, and incorporated herein by reference in its 
entirety for all purposes. 

[0002] This application claims the benefit of U.S. Provisional Application Serial No. 

60/432,440, entitled "Random Access For Wireless Multiple-Access Communication 
Systems," filed on December 10, 2002, assigned to the assignee of the present 
application, and incorporated herein by reference in its entirety for all purposes. 

BACKGROUND 

[0003] The present invention relates generally to data communication, and more 

specifically to techniques for facilitating random access in wireless multiple-access 
communication systems. 

Background 

[0004] Wireless communication systems are widely deployed to provide various types 

of communication such as voice, packet data, and so on. These systems may be 
multiple-access systems capable of supporting communication with multiple user 
terminals by sharing the available system resources. Examples of such multiple-access 
systems include code division multiple access (CDMA) systems, time division multiple 
access (TDMA) systems, and frequency division multiple access (EDMA) systems. 

[0005] In a multiple-access communication system, a number of user terminals may 

desire to gain access to the system at random times. These user terminals may or may 
not have registered with the system, may have timing that is skewed with, respect to 
system timing, and may or may not know the propagation delays to their access points. 
Consequently, the transmissions from user terminals attempting to gain access to the 
system may occur at random times, and may or may not be properly time-aligned at a 
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MIMO SYSTEM WITH MULTIPLE SPATIAL MULTIPLEXING 

MODES 

I. Claim of Priority under 35 U.S.C. §119 
[0001] The present Application for Patent claims priority to Provisional Application 

Serial No. 60/421,309, entitled "MMO WLAN System," filed October 25, 2002, 
assigned to the assignee hereof, and expressly incorporated by reference herein. 

BACKGROUND 

I. Field 

[0002] The present invention relates generally to communication, and more specifically 

to a multiple-input multiple-output (MIMO) communication system with multiple 
transmission modes. 

IL Background 

[0003] A MMO system employs multiple (N T ) transmit antennas and multiple (N R ) 

receive antennas for data transmission and is denoted as an (N T y N R ) system. A MMO 
channel formed by the Nt transmit and N R receive antennas may be decomposed into Ns 
spatial channels, where N s £min{N r , N R ] . The N s spatial channels may be used to 
transmit N s independent data streams to achieve greater overall throughput. In general, 
spatial processing may or may not be performed at a transmitter and is normally 
performed at a receiver to simultaneously transmit and recover multiple data streams. 

[0004] A conventional MIMO system typically uses a specific transmission scheme to 

simultaneously transmit, multiple data streams. This transmission scheme may be 
selected based on a trade-off of various factors such as the requirements of the system, 
the amount of feedback from the receiver to the transmitter, the capabilities of the 
transmitter and receiver, and so on. The transmitter, receiver, and system are then 
designed to support and operate in accordance with the selected transmission scheme. , 
This transmission scheme typically has favorable features as well as unfavorable ones, 
which can impact system performance. 
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[0005] There is therefore a need in the art for a MIMO system capable of achieving 

improved performance. 



SUMMARY 

[0006] A MIMO system that supports multiple spatial multiplexing modes for improved 

performance and greater flexibility is described herein. Spatial multiplexing refers to 
the transmission of multiple data streams simultaneously via multiple spatial channels 
of a MIMO channel. The multiple spatial multiplexing modes may include (1) a single- 
user steered mode that transmits multiple data streams on orthogonal spatial channels to 
a single receiver, (2) a single-user non-steered mode that transmits multiple data streams 
from multiple antennas to a single receiver without spatial processing at a transmitter, 
(3) a multi-user steered mode that transmits multiple data streams simultaneously to 
multiple receivers with spatial processing at a transmitter, and (4) a multi-user non- 
steered mode that transmits multiple data streams from multiple antennas (co-located or 
non co-located) without spatial processing at the transmitters) to receiver(s) having 
multiple antennas. 

[0007] A set of at least one user terminal is selected for data transmission on the 

downlink and/or uplink. A spatial multiplexing mode is selected for the user terminal 
set from among the multiple spatial multiplexing modes supported by the system. 
Multiple rates are also selected for multiple data streams to be transmitted via multiple 
spatial channels of a MIMO channel for the user terminal set. The user terminal set is 
scheduled for data transmission on the downlink and/or uplink with the selected rates 
and the selected spatial multiplexing mode. Thereafter, multiple data streams are 
processed (e.g., coded, interleaved, and modulated) in accordance with the selected rates 
and further spatially processed in accordance with the selected spatial multiplexing 
mode for transmission via multiple spatial channels. 

[0008] Various aspects and embodiments of the invention are described in further detail 

below. 
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BRIEF DESCRIPTION OF THE DRAWINGS 
[0009] FIG. 1 shows a multiple-access MMO system; 

[0010] FIG. 2 shows a frame and channel structure for the MIMO system; 

[0011] FIG. 3 shows an access point and two user terminals in the MIMO system; 

[0012] FIG. 4 shows a transmit (TX) data processor at the access point; 

[0013] FIG. 5 shows a TX spatial processor and modulators at the access point; 

[0014] FIG. 6 shows demodulators and a receive (RX) spatial processor at a multi- 

antenna user terminal; 
[0015] FIG. 7 shows an RX data processor at the multi-antenna user terminal; 

[0016] FIG. 8 shows an RX spatial processor and an RX data processor that implement 

a successive interference cancellation (SIC) technique; 

[0017] FIG. 9 shows the transmit/receive chains at the access point and user terminal; 

[0018] FIG. 10 shows a closed-loop rate control mechanism; 

[0019] FIG. 1 1 shows a controller and a scheduler for scheduling user terminals; 

[0020] FIG. 12 shows a process for scheduling user terminals for data transmission; 

[0021] FIG. 13 shows a process for transmitting data on the downlink; and 

[0022] FIG. 14 shows a process for receiving data on the uplink. 

DETAILED DESCRIPTION 

[0023] The word "exemplary" is used herein to mean "serving as an example, instance, 

or illustration." Any embodiment described herein as "exemplary" is not necessarily to 
be construed as preferred or advantageous over other embodiments. 

[0024] A MIMO system may utilize a single carrier or multiple carriers for data 

transmission. Multiple carriers may be provided by orthogonal frequency division 
multiplexing (OFDM), other multi-carrier modulation techniques, or some other 
constructs. OFDM effectively partitions the overall system bandwidth into multiple 
(N F ) orthogonal subbands, which are also commonly referred to as tones, bins, carriers, 
and frequency channels. With OFDM, each subband is associated with a respective 
carrier that may be modulated with data. The following description is for a MIMO 
system that utilizes OFDM. However, the concepts described herein are equally 
applicable for a single carrier MIMO system. 
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[0025] The 1VQMO system supports multiple spatial multiplexing modes for improved 

performance and greater flexibility. Table 1 lists the supported spatial multiplexing 
modes and their short descriptions. 



Table 1 



Spatial 
Multiplexing Mode 


Description 


Single-User 
Steered 


Multiple data streams are transmitted on orthogonal spatial 
channels to a single receiver. 


Single-User 
Non-Steered 


Multiple data streams are transmitted from multiple antennas to 
a single receiver without spatial processing at a transmitter. 


Multi-User 
Steered 


Multiple data streams are transmitted simultaneously (1) from a 
single transmitter to multiple receivers or (2) from multiple 
transmitters to a single receiver, both with spatial processing at 
the transmitter(s). 


Multi-User 
Non-Steered 


Multiple data streams are transmitted simultaneously (1) from 
multiple transmitters to a single receiver or (2) from a single 
transmitter to multiple receivers, both without spatial 
processing at the transmitter(s). 



The MIMO system may also support other and/or different spatial multiplexing modes, 
and this is within the scope of the invention. 
[0026] Each spatial multiplexing mode has different capabilities and requirements. The 

steered spatial multiplexing modes can typically achieve better performance but can 
only be used if the transmitter has sufficient channel state information to orthogonalize 
the spatial channels via decomposition or some other technique, as described below. 
The non-steered spatial multiplexing modes require very little information to 
simultaneously transmit multiple data streams, but performance may not be quite as 
good as the steered spatial multiplexing modes. A suitable spatial multiplexing mode 
may be selected for use depending on the available channel state information, the 
capabilities of the transmitter and receiver, system requirements, and so on. Each of 
these spatial multiplexing modes is described below. 

1. Single-User Steered Spatial Multiplexing Mode 

[0027] A frequency-selective MIMO channel formed by N T transmit antennas and Nr 

receive antennas may be characterized by Nf frequency-domain channel response 
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matrices H(Jk), for jfc = l ... N F , each with dimensions of N R xN T . The channel 
response matrix for each subband may be expressed as: 



H(*) = 



KJk) h Nit>2 (k) - K RtNT {k) 



Eq(l) 



where entry h UJ (k) , for f = l ... iV*, 7 = 1 ... N T , and fc = l ... is the coupling 
(i.e., complex gain) between transmit antenna j and receive antenna i for subband k. 

[0028] The channel response matrix H(£) for each subband may be "diagonalized" to 

. obtain N s eigenmodes for that subband. This diagonalization may be achieved by 
performing either singular value decomposition of the channel response matrix H(fc) or 
eigenvalue decomposition of a correlation matrix of H(fc), which is 
R(jfc) = H* (fc)H(fc) , where " H " denotes the conjugate transpose. 

[0029] The singular value decomposition of the channel response matrix H(fc) for each 

subband may be expressed as: 



E(k) = V(k)X(k)V H (k) , 



Eq(2) 



where U(fc) is an (N R xN R ) unitary matrix of left eigenvectors of H(fc) ; 

2(fc) is an (N R xN T ) diagonal matrix of singular values of H(£) ; and 
V(Jfc) is an (N T xN T ) unitary matrix of right eigenvectors of H(fc) . 

A unitary matrix M is characterized by the property M W M = I, where I is the identity 
matrix. The columns of a unitary matrix are orthogonal to one another. 
[0030] The eigenvalue decomposition of the correlation matrix of H(fc) for each 

subband may be expressed as: 



= H" (fc)H(ifc) = V(*)A(*)V* (k) , 



Eq(3) 
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where A(fc) is an (N T xN T ) diagonal matrix of eigenvalues of R(£). As shown in 
equations (2) and (3), the columns of V(fc) are eigenvectors of R(fc) as well as right 
eigenvectors of H(fc) . 

[0031] Singular value decomposition and eigenvalue decomposition are described by 
Gilbert Strang in a book entitled lc Linear Algebra and Its Applications " Second Edition, 
Academic Press, 1980. The single-user steered spatial multiplexing mode may be 
implemented with either singular value decomposition or eigenvalue decomposition. 
For clarity, singular value decomposition is used for the following description. 
[0032] The right eigenvectors of H(fc) are also referred to as "steering" vectors and may be 
used for spatial processing by a transmitter to transmit data on the Ns eigenmodes of 
H(fc) . The left eigenvectors of H(ifc) may be used for spatial processing by a receiver 
to recover the data transmitted on the Ns eigenmodes. The eigenmodes may be viewed 
as orthogonal spatial channels obtained through decomposition. The diagonal matrix 
2(fc) contains non-negative real values along the diagonal and zeros elsewhere. These 
diagonal entries are referred to as the singular values of H(fc) and represent the channel 
gains for the N s eigenmodes of H(&). The singular values of H(fc), 
{a^k) a 2 (k) ... a Ns (k)}, are also the square roots of the eigenvalues of R(fc), 
W*) >W - where = Singular value decomposition may be 

performed independently on the channel response matrix H(fc) for each of the N F 
subbands to determine the Ns eigenmodes for that subband. 
[0033] For each subband, the singular values in the matrix may be ordered from 

largest to smallest, and the eigenvectors in the matrices V(k) and U(fc) may be ordered 
correspondingly. A "wideband" eigenmode may be defined as the set of same-order 
eigenmodes of all N F subbands after the ordering (i.e., wideband eigenmode m includes 
eigenmode m of all subbands). In general, all or fewer than Nf subbands may be used 
for transmission, with the unused subbands being filled with signal values of zero. For 
simplicity, the following description assumes that all N F subbands are used for 
transmission. 

[0034] The single-user steered spatial multiplexing mode (or simply, the "single-user 

steered mode") transmits N s data symbol streams on the N s eigenmodes of the MEMO 
channel. This requires spatial processing by both the transmitter and the receiver. 
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[0035] The spatial processing at the transmitter for each subband for the single-user 

steered mode may be expressed as: 

x, tt -,(*)=Y(fc)s(*) , E q( 4 ) 

where s(jfc) is an (N T xl) vector with N s non-zero entries for N s data symbols to be 
transmitted on the N$ eigenmodes for subband k\ and 
x JU _,(it) is an (N T xl) vector with N T entries for N T transmit symbols to be sent 
from the Nt transmit antennas for subband k. 
The N s entries of s(k) can represent N s data symbol streams and the remaining entries 
of s(ifc) , if any, are filled with zeros. 
[0036] The received symbols obtained by the receiver for each subband may be 

expressed as: 

r , M _, (k) = H(fc)x^ (k) + n(k) = H(fc) \(k)s(k) + n(k) , Eq (5) 

where ^(jt) is an (N R xl) vector with N R entries for N R received symbols obtained 
via the Nr receive antennas for subband k\ and 
n(k) is a noise vector for subband k. 

[0037] The spatial processing at the receiver to recover the data vector s(fc) for each 

subband may be expressed as: 



Eq(6) 



!,„(*) =IT\k)U H (k)r 5U _,(k) , 

= S" 1 (k)V" (fc)(H(fc)V(fc)s(fc) + n(fc)) , 
= (k)V H (k)(Mk)Um H (*)¥(*)s(fc) + n(k)) , 
= s(k) + n 5U _ s (k) , 

or l 5U - 5 (k) = V H (k)r su ^k) and s^(fc) = (k)s su _ s (k) , 

where I^(fc) is an (N T xl) vector with N s detected data symbols for subband k\ 

hu-s(k) is an (N T xl) vector with A/j recovered data symbols for subband k\ and 
n su _ s (k) is a vector of post-processed noise for subband k. 
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The vector s_ su ^(k) is an unnormalized estimate of the data vector s(fc) , and the vector 
s su . s (k) is a normalized estimate of s(k) . The multiplication by IT\k) in equation (6) 
accounts for the (possibly different) gains of the Ns spatial channels and normalizes the 
output of the receiver spatial processing so that recovered data symbols with the proper 
magnitude are provided to a subsequent processing unit. 
[0038] For the single-user steered mode, the matrix ¥ 5U . S (k) of steering vectors used by 

the transmitter for each subband may be expressed as: 

F ra .,(t) = Y« . Eq(7) 

The spatial filter matrix used by the receiver for each subband may be expressed as: 

M 5U „ s (k) = V H (k) . Eq(8) 

[0039] The single-user steered mode may be used if the transmitter has channel state 

information for either the channel response matrix H(fc) or the matrix V(£) of right 
eigenvectors of H(fc) , for k = 1 ... N F . The transmitter can estimate H(fc) or V(fc) for 
each subband based on a pilot transmitted by the receiver, as described below, or may 
be provided with this information by the receiver via a feedback channel. The receiver 
can typically obtain H(fc) or V H (k) for each subband based on a pilot transmitted by 
the transmitter. Equation (6) indicates that the N s data symbol streams s(fc), distorted 
only by post-processed channel noise n su _ s (k) y may be obtained for the single-user 
steered mode with the proper spatial processing at both the transmitter and the receiver. 

[0040] The signal-to-noise-and-interference ratio (SNR) for the single-user steered 

mode may be expressed as: 

Y^Jk) = P ^ {k) , m=l ... N s , Eq(9) 

where P m (k) is the transmit power used for the data symbol transmitted on subband k 
of wideband eigenmode m\ 
JL m (k) is the eigenvalue for subband k of wideband eigenmode m, which is the 

m-th diagonal element of A(k) ; and 
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y (k) is the SNR for subband k of wideband eigenmode m. 

2. Single-User Non-Steered Spatial Multiplexing Mode 

[0041] The single-user non-steered spatial multiplexing mode (or simply, the "single- 

user non-steered mode") may be used if the transmitter does have not sufficient channel 
state information or if the single-user steered mode cannot be supported for any reasons. 
The single-user non-steered mode transmits Ns data symbol streams from Nt transmit 
antennas without any spatial processing at the transmitter. 

[0042] For the single-user non-steered mode, the matrix F w (k) of steering vectors used 

by the transmitter for each subband may be expressed as: 

L(Jfc) = I . Bq(10) 

The spatial processing at the transmitter for each subband may be expressed as: 

X W (*) = S(*) , Bq(ll) 

where x„(it) is the transmit symbol vector for the single-user non-steered mode. A 
"wideband" spatial channel for this mode may be defined as the spatial channel 
corresponding to a given transmit antenna (i.e., wideband spatial channel m for the 
single-user non-steered mode includes all subbands of transmit antenna m). 
[0043] The received symbols obtained by the receiver for each subband may be 

expressed as: 

= H(ifc)x nj (^ . Eq(12) 

The receiver can recover the data vector s(k) using various receiver processing 
techniques such as a channel correlation matrix inversion (CCNH) technique (which is 
also commonly referred to as a zero-forcing technique), a minimum mean square error 
(MMSE) technique, a decision feedback equalizer (DEE), a successive interference 
cancellation (SIC) technique, and so on. 
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A. CCMI Spatial Processing 
[0044] The receiver can use the CCMI technique to separate out the data symbol 

streams. A CCMI receiver utilizes a spatial filter having a response of M ccmi (k) , for 
k = 1 ... N F , which can be expressed as: 

M ccm ,(*) = [H* (*)H(*)] - 1 H* (jfc) = R l (*)S* (*) . Eq (13) 

[0045] The spatial processing by the CCMI receiver for the single-user non-steered 

mode may be expressed as: 

§«*,(*) =M can/ (fe)r w (fe) , 

= RT 1 (Jfc)H w (Jt)(H(fc)s(fc) + n(Jfc)) , Eq (14) 

= s(fe)+n caBi (t) , 

where s ccmi (k) is an (N T xl) vector with iV 5 recovered data symbols for subband k\ and 
D«mf (*) = Mean/ (*)n(*0 is the CCMI filtered noise for subband h 
[0046] An autocovariance matrix <P cani (k) of the CCMI filtered noise for each subband 

may be expressed as: 

2ccm .(k) =£[n ran( (*)nL(*)] • 

=m otb ,(*)£ b (*)mL(*) . E q( 15 > 

= cr 2 R-'(fe) , 

where E[x] is the expected value of x. The last equality in equation (15) assumes that 
the noise n(fc) is additive white Gaussian noise (AWGN) with zero mean, a variance of 
a 2 , and an autocovariance matrix of (p (fc) = E\n(k)n" (k)] = <r 2 I . In this case, the 

— nn 

SNR for the CCMI receiver may be expressed as: 

»>-rS£?- - = l-^. Eq(16) 
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where P m (k) is the transmit power used for the data symbol transmitted on subband k 
of wideband spatial channel m; 
r mm (jfc) is the wi-th diagonal element of R(fc) for subband k, and 

YccmisnW) is * c SNR for subband k of wideband spatial channel m. 
Due to the structure of R(fc) , the CCMI technique may amplify the noise. 

B. MMSE Spatial Processing 
[0047] The receiver can use the MMSE technique to suppress crosstalk between the 

data symbol streams and maximize the SNRs of the recovered data symbol streams. An 
MMSE receiver utilizes a spatial filter having a response of M^Cfc) , for k = 1 ... N F , 
which is derived such that the mean square error between the estimated data vector from 
the spatial filter and the data vector s(£) is minimized. This MMSE criterion may be 
expressed as: 

.min E [(MnuuMl*, (*) -»(*))* (M™™ (*)E« (*) - §(*))] • Bq(17) 

[0048] The solution to the optimization problem posed in equation (17) may be 

obtained in various manners. In one exemplary method, the MMSE spatial filter matrix 
M mmse (k) for each subband may be expressed as: 

M_(fc) =H"(A:)[H(*)H H (t) + ^ n (fc)]" 1 , 

fcq UoJ 

= H H (jfc)[H(jk)H ,^ (^)+o■ 2 I]- , . 

The second equality in equation (18) assumes that the noise vector n(fc) is AWGN 

with zero mean and variance of a 1 . 
[0049] The spatial processing by the MMSE receiver for the single-user non-steered 

mode is composed of two steps. In the first step, the MMSE receiver multiplies the 
vector r^ik) for the N R received symbol streams with the MMSE spatial filter matrix 
Mmm*(]k) to obtain a vector (fc) for N s detected symbol streams, as follows: 
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=M™™(*)l*(*) . 

= M mroe (Jfc)(H(*)s(fc) + n(fc)) , Eq (19) 

= Q(«S(*) + !!■«■(*) . 



where = M^ttMtt is the MMSE filtered noise and Q(*) = M mww (fc)H(*) . 

The Ns detected symbol streams are unnormalized estimates of the Ns data symbol 
streams. 

[0050] In the second step, the MMSE receiver multiplies the vector JL„«(&) with a 

scaling matrix D^(Jk) to obtain a vector l^C*) for the N s recovered data symbol 
streams, as follows: 

I— («=eL(«i— (« . E( i( 20 > 

where D mmw (&) is a diagonal matrix whose diagonal elements are the diagonal elements 
of Q(Jfc), i.e., D MMe (ifc) = diag [Q(Jk)]. The N s recovered data symbol streams are 
normalized estimates of the N s data symbol streams. 
[0051] Using the matrix inverse identity, the matrix Q(k) can be rewritten as: 

Q(*) -H H (fc)^^fc)H(A:)[H H (fc)^(*)H(fc)+I]- 1 , 

" ~ m Eq (21) 

= H w (fc)H(it)[H H (fc)H(A:) + o- 2 I]"- 1 . 

The second equality in equation (21) assumes that the noise is AWGN with zero mean 

and variance of cr 2 . 
[0052] The SNR for the MMSE receiver may be expressed as: 

where q^ik) is the m-th diagonal element of Q{k) for subband fc; and 

y mmse ^(k) is the SNR for subband k of wideband spatial channel m. 



WO 2004/038984 



PCT/US2003/034519 



13 

C. Successive Interference Cancellation Receiver Processing 
[0053] The receiver can process the N R received symbol streams using the SIC 

technique to recover the Ns data symbol streams. For the SIC technique, the receiver 
initially performs spatial processing on the N R received symbol streams (e.g., using 
CCMI, MMSE, or some other technique) and obtains one recovered data symbol 
stream. The receiver further processes (e.g., demodulates, deinterleaves, and decodes) 
this recovered data symbol stream to obtain a decoded data stream. The receiver then 
estimates the interference this stream causes to the other N s -1 data symbol streams 
and cancels the estimated interference from the N R received symbol streams to obtain N R 
modified symbol streams. The receiver then repeats the same processing on the N R 
modified symbol streams to recover another data symbol stream. 
[0054] For a SIC receiver, the input (i.e., received or modified) symbol streams for 

stage £ , where I = 1 ... N s , may be expressed as: 

r ( 5ic (k) = H'(*)x^ (*) + n(*) = HW (*) +a(« . E( l ( 23 > 

where r e sic (k) is a vector of N R modified symbols for subband k in stage £, and 

t\ic ( fc ) " Ins ( k ) for the firSt Sta S e » 

s'(fc) is a vector of (N T -£ + 1) data symbols not yet recovered for subband k in 
stage £ ; and 

H' (k) is an N R x(N T -£ + 1) reduced channel response matrix for subband k in 
stage £ . 

[0055] Equation (23) assumes that the data symbol streams recovered in the (£-1) 

prior stages are canceled. The dimensionality of the channel response matrix H(A) 
successively reduces by one column for each stage as a data symbol stream is recovered 
and canceled. For stage £, the reduced channel response matrix H'(fc) is obtained by 
removing (^-1) columns in the original matrix H(fc) corresponding to the (^-1) data 
symbol streams previously recovered, i.e., H'(£) = [h^(fc) h jM (k) ... h Jjfr (i)] f where 
h ; (k) is an N R xl vector for the channel response between transmit antenna j n and the 
N R receive antennas. For stage £ , the (£ - 1) data symbol streams recovered in the prior 
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stages are given indices of {;', j 2 ... j M ) , and the (N T -£ + 1) data symbol streams not 
yet recovered are given indices of {j ( j M ... j Nr } . 

[0056] For stage £, the SIC receiver derives a spatial filter matrix M* sic (k), for 

k- \ ... N F , based on the reduced channel response matrix H f (fc) (instead of the 
original matrix H(£)) using the CCMI technique as shown in equation (13), the MMSE 
technique as shown in equation (18), or some other technique. The matrix M' k (*) has 
dimensionality of (JV r -£ + l)xN R . Since H*(fc) is different for each stage, the spatial 
filter matrix M ( sic (k) is also different for each stage. 

[0057] The SIC receiver multiplies the vector r^(fc) for the N R modified symbol 

streams with the spatial filter matrix M l sic (k) to obtain a vector s^(fe) for (N T -£ + 1) 
detected symbol streams, as follows: 

lUk) =ML(*)rL(*) , 

= M; ic (A:)(H / (^(/:) + n < (fc)) , Eq (24) 

= Q^*)s'(*)+i4(*) , 

where n e 5ic (k) = M e sic (k)n (k) is the filtered noise for subband k of stage £, n\k) is a 
reduced vector of n(ifc) , and Q' /c (fc) = M^k)^ (k) . The SIC receiver then selects one 
of the detected symbol streams for recovery. Since only one data symbol stream is 
recovered in each stage, the SIC receiver can simply derive one (lxN*) spatial filter 

row vector m e Jt (k) for the data symbol stream {s jt } to be recovered in stage £. The 
row vector m j( (k) is one row of the matrix M^ik) . In this case, the spatial processing 
for stage I to recover the data symbol stream {s Jg } may be expressed as: 

s jt (k) = m^(k)v^ , Eq (25) 

where q' (k) is the row of Q[ ic (k) corresponding to data symbol stream {s Jt } . 
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[0058] In any case, the receiver scales the detected symbol stream {s h } to obtain a 

recovered data symbol stream {s jt } and further processes (e.g., demodulates, 
deinterleaves, and decodes) the stream {S Jt } to obtain a decoded data stream {d j( } . The 

receiver also forms an estimate of the interference this stream causes to the other data 
symbol streams not yet recovered. To estimate the interference, the receiver re-encodes, 
interleaves, and symbol maps the decoded data stream {d J( } in the same manner as 
performed at the transmitter and obtains a stream of "remodulated" symbols [s Jt } , 
which is an estimate of the data symbol stream just recovered. The receiver then 
convolves the remodulated symbol stream with each of Nr elements in the channel 
response vector h j( ( k ) for stream {•*/,} to obtain Nr interference components l Jt (k) 
caused by this stream. The Nr interference components are then subtracted from the Nr 
modified symbol streams r e sic (k) for stage £ to obtain Nr modified symbol streams 
r%\k) for the next stage £ + 1, i.e., r£(fc) = r e s{c (k)-i Ji (k) . The modified symbol 
streams r™(k) represent the streams that would have been received if the data symbol 
stream {s j( } had not been transmitted (i.e., assuming that the interference cancellation 

was effectively performed). 

[0059] The SIC receiver processes the N R received symbol streams in N s successive 

stages. For each stage, the SIC receiver (1) performs spatial processing on either the N R 
received symbol streams or the N R modified symbol streams from the preceding stage to 
obtain one recovered data symbol stream, (2) decodes this recovered data symbol 
stream to obtain a corresponding decoded data stream, (3) estimates and cancels the 
interference due to this stream, and (4) obtains N R modified symbol streams for the next 
stage. If the interference due to each data stream can be accurately estimated and 
canceled, then later recovered data streams experience less interference and may be able 
to achieve higher SNRs. 

[0060] For the SIC technique, the SNR of each recovered data symbol stream is 

dependent on (1) the spatial processing technique (e.g., CCMI or MMSE) used for each 
stage, (2) the specific stage in which the data symbol stream is recovered, and (3) the 
amount of interference due to data symbol streams recovered in later stages. The SNR 
for the SIC receiver with CCMI may be expressed as: 
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where r^(&) is the m-th diagonal element of [R'(fc)]~' for subband k, where 

R'(*) = [HW H'(fc). 
[0061] The SNR for the SIC receiver with MMSE may be expressed as: 

r,,™„(*) = 7%^/]»« • /«=l...iV s . Eq(27) 

where is the m-th diagonal element of Q' fc (£) for subband k, where Q e sic (k) is 

derived as shown in equation (21) but based on the reduced channel response matrix 
g'(fc) instead of the original matrix H(fc) . 
[0062] In general, the SNR progressively improves for data symbol streams recovered 

in later stages because the interference from data symbol streams recovered in prior 
stages is canceled. This then allows higher rates to be used for data symbol streams 
recovered later. 

3. Multi-User Steered Spatial Multiplexing Mode 

[0063] The multi-user steered spatial multiplexing mode (or simply, the "multi-user 

steered mode") supports data transmission from a single transmitter to multiple 
receivers simultaneously based on "spatial signatures" of the receivers. The spatial 
signature for a receiver is given by a channel response vector (for each subband) 
between the N T transmit antennas and each receive antenna at the receiver. The 
transmitter may obtain the spatial signatures for the receivers as described below. The 
transmitter may then (1) select a set of receivers for simultaneous data transmission and 
(2) derive steering vectors for the data symbol streams to be transmitted to the selected 
receivers such that transmit stream crosstalk is adequately suppressed at the receivers. 

[0064] The steering vectors for the multi-user steered mode may be derived in various 

manners. Two exemplary schemes are described below. For simplicity, the following 
description is for one subband and assumes that each receiver is equipped with one 
antenna. 
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[0065] In a channel inversion scheme, the transmitter obtains the steering vectors for 

multiple receivers using channel inversion. The transmitter initially selects N T single- 
antenna receivers for simultaneous transmission. The transmitter obtains a lxJV r 
channel response row vector h,(£) for each selected receiver and forms an N T xN T 
channel response matrix H^tfc) with the N T row vectors for the N T receivers. The 
transmitter then uses channel inversion to obtain a matrix Emu-s(k) of n t steering 
vectors for the Nt selected receivers, as follows: 

F mu _,(fe)=H;L« . E <i( 28 > 

[0066] The spatial processing at the transmitter for each subband for the multi-user 

steered mode may be expressed as: 

x mu ^k)^F mu ^k)s(k) . Eq(29) 

where x m „_ a (ifc) is the transmit symbol vector for the multi-user steered mode. 
[0067] The received symbols at the N T selected receivers for each subband may be 

expressed as: 

Emu-,(*0 =H-«(*)l-«(*)+!l(*) , 

= IL.(i)E^W)+n(« , Eq(30) 
= s(Jfc) + i(Jk) + n(Jk) , 

where r mtt , s (k) is an (N T xl) received symbol vector for subband k at the N T selected 
receivers, and i(fc) represents the crosstalk interference due to imperfect estimation of 
F mu _ s (k) at the transmitter. Each selected receiver would obtain only one entry of the 
vector r^ik) for each receive antenna. If the spatial processing at the transmitter is 
effective, then the power in i(k) is small, and each recovered data symbol stream 
experiences little crosstalk from the (7V r — 1) other data symbol streams sent to the 
other receivers. 

[0068] The transmitter can also transmit a steered pilot to each selected receiver, as 

described below. Each, receiver would then process its steered pilot to estimate the 
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channel gain and phase and coherendy demodulate the received symbols from its single 
antenna with the channel gain and phase estimates to obtain recovered data symbols. 



autocovariance of the channel response matrix B^^ik) . Higher SNRs can be achieved 
by selecting "compatible" user terminals. Different sets and/or combinations of user 
terminals may be evaluated, and the set/combination with the highest SNRs may be 
selected for data transmission. 



will provide poor performance, because preconditioning the data symbol streams with 
the inverse channel response matrix in equation (29) forces the transmitter to put the 
majority of its power in the worst eigenmodes of the MEMO channel. Also, in some 
channels, particularly those with large correlations among the elements of H /nw _ 5 (A:), the 
channel response matrix is less than full rank, and calculating an inverse will not be 
possible. 

[0071] In a preceding scheme, the transmitter precodes N T data symbol streams to be 

sent to the N T selected receivers such that these data symbol streams experience little 
crosstalk at the receivers. The transmitter can form the channel response matrix 
H mu (k) for the N T selected receivers. The transmitter then performs QR factorization 
on H mr ,(*) such that H mu (fc) = F /n -(fc)Q mu (fe) , where F^(fc) is a lower left triangular 
matrix and Q^OO is a unitary matrix. 

[0072] The transmitter performs a precoding operation on the data symbol vector to be 

transmitted, s(ifc) = [s t (fc) s 2 (k) ... s Nt (k)] T , to obtain a precoded symbol 
vector a(fc) = [a x (k) a 2 (k) ... a Nj (k)f , as follows: 



[0069] 



The SNRs achieved for the multi-user steered mode are a function of the 



[0070] 



While the channel inversion scheme is appealing in its simplicity, in general, it 



*«(*) = 




T ' 



Eq(31) 



where M is the number of levels, spaced at unit intervals, in the in-phase or quadrature 
dimension of a square QAM signal constellation; and 
f ei (k) is the element of F lrf (£) in row i and column./. 
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The modulo (mod) operation adds a sufficient number of integer multiples of M to the 
argument so that the result satisfies a ( (k)e [-M /2,M /2). After this precoding 
operation, the transmit symbols are computed by processing the precoded symbol vector 
a(&) with the unitary steering matrix Q^ik) to generate the transmit symbol vector 

[0073] The receive symbol vector for the precoding scheme can be expressed as: 

W« = H^(^ . Eq(32) 

It can be shown that F, w (*)a(A;) mod {M 12)- s(k) . Thus, the data symbol vector can 
be estimated as s mu _ pc (k) = r (fc) mod {Ml 2). Each of the N T selected receivers 
only obtains one of the N T elements of r mu _ pc {k) and can estimate the data symbols sent 
to it by performing the mod(M 12) operation on its received symbols. 
[00741 The transmitter can also transmit multiple data symbol streams to a multi- 

antenna receiver in the multi-user steered mode. The channel response matrix R mu (k) 
would then include one row vector for each receive antenna of the multi-antenna 
receiver. 

[0075] The multi-user steered mode also supports data transmission from multiple 

multi-antenna transmitters to a single receiver. Each multi-antenna transmitter performs 
spatial processing on its data symbol stream to steer the stream toward the receiver. 
Each transmitter also transmits a steered pilot to the receiver. To the receiver, each 
transmitter appears as a single transmission. The receiver performs spatial processing 
(e.g., CCMI, MMSE, and so on) to recover the steered data symbol streams from all 
transmitters. 

4. Multi-User Non-Steered Spatial Multiplexing Mode 

[0076] The multi-user non-steered spatial multiplexing mode (or simply, the "multi-user 

non-steered mode") supports simultaneous data transmission by (1) a single transmitter 
to multiple receivers (e.g., for the downlink) and (2) multiple transmitters to a single 
receiver (e.g., for the uplink). 

[0077] For non-steered transmission from a single transmitter to multiple receivers, the 

transmitter transmits one data symbol stream from each transmit antenna for a recipient 
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receiver. One or multiple data symbol streams may be transmitted for each recipient 
receiver. Each recipient receiver includes at least Nt receive antennas and can perform 
spatial processing to isolate and recover its data symbol stream(s). Each receiver 
desiring data transmission estimates the SNR for each of the Nt transmit antennas and 
sends the Nt SNR estimates to the transmitter. The transmitter selects a set of receivers 
for data transmission based on the SNR estimates from all receivers desiring data 
transmission (e.g., to maximize the overall throughput). 
[0078] For non-steered transmission from multiple transmitters to a single receiver, the 

transmitters transmit data symbol streams from their antennas (i.e., without spatial 
processing) such that these streams arrive approximately time-aligned at the receiver. 
The receiver can estimate the channel response matrix for all of the transmitters as if 
they were one transmitter. The receiver can recover multiple data symbol streams 
transmitted by these multiple transmitters using any of the techniques described above 
for the single-user non-steered mode (e.g., CCMI, MMSE, and SIC techniques). 

5. Spatial Processing 

[0079] Table 2 summarizes the spatial processing at the transmitter and the receiver for 

the four spatial multiplexing modes described above. For the non-steered modes, 
receiver processing techniques other than CCMI and MMSE may also be used. The last 
column in Table 2 indicates whether or not the SIC technique may be used at the 
receiver. 
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[0080J 

Table 2 



Spatial Multiplexing 
Mode 


Transmit 
F(fc) 


Receive 
M(fc) 


Scaling 


SIC 


Single-User Steered 


¥(*) 


XJ H (k) 




no 


Single-User 
Non-Steered 


I 


M cani (k) 




yes 


Multi-User Steered 
(single transmitter to 
multiple receivers) 








no 


Multi-User 

Non-Steered (multiple 
transmitters to single 
receiver) 


I 


M cmi (k) 
M mmse (k) 


Blew 


yes 



For simplicity, the spatial processing for the multi-user steered mode from multiple 
transmitters to a single receiver and the multi-user non-steered mode from a single 
transmitter to multiple receivers are not shown in Table 2. 
[0081] In the following description, a wideband spatial channel can correspond to (1) a 

wideband eigenmode, for a steered spatial multiplexing mode, (2) a transmit antenna, 
. for a non-steered spatial multiplexing mode, or (3) a combination of one or more spatial 
channels of one or more subbands. A wideband spatial channel can be used to transmit 
one independent data stream. 

6, MEMO System 

[0082] FIG, 1 shows a multiple-access MEMO system 100 with a number of access 

points (APs) 110 providing communication for a number of user terminals (UTs) 120. 
For simplicity, only two access points 110a and 110b are shown in FIG. 1. An access 
point is generally a fixed station that communicates with the user terminals and may 
also be referred to as a base station or some other terminology. A user terminal may be 
fixed or mobile and may also be referred to as a mobile station, a wireless device, or 
some other terminology. A system controller 130 couples to and provides coordination 
and control for access points 1 10. 
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[0083] MMO system 100 may be a time division duplex (TDD) system or a frequency 

division duplex (FDD) system. The downlink and uplink (1) share the same frequency 
band for a TDD system and (2) use different frequency bands for an FDD system. The 
following description assumes that MMO system 100 is a TDD system. 

[0084] MMO system 100 utilizes a set of transport channels to transmit different types 

of data. The transport channels may be implemented in various manners. 

[0085] FIG. 2 shows an exemplary frame and channel structure 200 that may be used 

for MMO system 100. Data transmission occurs in TDD frames. Each TDD frame 
spans a predetermined time duration (e.g., 2 msec) and is partitioned into a downlink 
phase and an uplink phase. Each phase is further partitioned into multiple segments 
210, 220, 230, 240, and 250 for multiple transport channels. 

[0086] In the downlink phase, a broadcast channel (BCH) carries a beacon pilot 214, a 

MMO pilot 216, and a BCH message 218. The beacon pilot is used for timing and 
frequency acquisition. The MMO pilot is used for channel estimation. The BCH 
message carries system parameters for the user terminals. A forward control channel 
(FCCH) carries scheduling information for assignments of downlink and uplink 
resources and other signaling for the user terminals. A forward channel (FCH) carries 
FCH protocol data units (PDUs) on the downlink. An FCH PDU 232a includes a pilot 
234a and a data packet 236a, and an FCH PDU 232b includes only a data packet 236b. 
In the uplink phase, a reverse channel (RCH) carries RCH PDUs on the uplink. An 
RCH PDU 242a includes only a data packet 246a, and an RCH PDU 242b includes a 
pilot 244b and a data packet 246b. A random access channel (RACH) is used by the 
user terminals to gain access to the system and to send short messages on the uplink. 
An RACH PDU 252 sent on the RACH includes a pilot 254 and a message 256. 
[0087] FIG. 3 shows a block diagram of an access point HOx and two ufer terminals 

120x and 120y in MMO system 100. Access point HOx is one of the access points in 
FIG. 1 and is equipped with multiple (N ap ) antennas 324a through 324ap. User terminal 
120x is equipped with a single antenna 352x, and user terminal 120y is equipped with 
multiple (N u{ ) antennas 352a through 352ut. 
[0088] On the downlink, at access point 1 lOx, a TX data processor 310 receives traffic 

data for one or more user terminals from a data source 308, control data from a 
controller 330, and possibly other data from a scheduler 334. The various types of data 
may be sent on different transport channels. TX data processor 310 processes (e.g., 
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encodes, interleaves, and symbol maps) the different types of data based on one or more 
coding and modulation schemes to obtain N s streams of data symbols. As used herein, a 
"data symbol" refers to a modulation symbol for data, and a "pilot symbol" refers to a 
modulation symbol for pilot. A TX spatial processor 320 receives the N s data symbol 
streams from TX data processor 310, performs spatial processing on the data symbols 
with matrices F ap (fc), for k =1 ... N F , multiplexes in pilot symbols, and provides 

streams of transmit symbols for the N ap antennas. The matrices F ap (&) are derived in 
accordance with the spatial multiplexing mode selected for use. The processing by TX 
data processor 310 and TX spatial processor 320 is described below. 
[0089] Each modulator (MOD) 322 receives and processes a respective transmit symbol 

stream to obtain a stream of OFDM symbols, and further conditions (e.g., amplifies, 
filters, and frequency upcon verts) the OFDM symbol stream to generate a downlink 
signal. Nap modulators 322a through 322ap provide N ap downlink signals for 
transmission from N ap antennas 324a through 324ap, respectively, to the user terminals. 
[0090] At each user terminal 120, one or multiple antennas 352 receive the N ap 

downlink signals, and each antenna provides a received signal to a respective 
demodulator (DEMOD) 354. Each demodulator 354 performs processing 
complementary to that performed by modulator 322 and provides a stream of received 
symbols. For single-antenna user terminal 120x, an RX spatial processor 360x performs 
coherent demodulation of the received symbol stream from a single demodulator 354x 
and provides one stream of recovered data symbols. For multi-antenna user terminal 
120y, RX spatial processor 360y performs spatial processing on N ut received symbol 
streams from N ut demodulators 354 with spatial filter matrices M w (fc) , for k = 1 ... N F , 
and provides streams of recovered data symbols. In any case, each recovered data 
symbol stream {s m } is an estimate of a data symbol stream {s m } transmitted by access 
point HOx to that user terminal 120. An RX data processor 370 receives and 
demultiplexes the recovered data symbols to the proper transport channels. The 
recovered data symbols for each transport channel are then processed (e.g., demapped, 
deinterleaved, and decoded) to obtain decoded data for that transport channel. The 
decoded data for each transport channel may include recovered traffic data, control data, 
and so on, which may be provided to a data sink 372 for storage and/or a controller 380 
for further processing. 
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[0091] At each user terminal 120, a channel estimator 378 estimates the downlink 

channel response and provides channel estimates, which may include channel gain 
estimates, SNR estimates, and so on. Controller 380 receives the channel estimates, 
derives the vectors and/or coefficients used for spatial processing on the transmit and . 
receive paths, and determines a suitable rate for each data symbol stream on the 
downlink. For example, controller 380y for multi-antenna user terminal 120y may 
derive the spatial filter matrices M ut (fc) for the downlink and the matrices F^A:) of 
steering vectors for the uplink based on downlink channel response matrices H^fc), 
for fc = l ... N F . Controller 380 may also receive the status of each packet/frame 
received on the downlink and assemble feedback information for access point HOx. 
The feedback information and uplink data are processed by a TX data processor 390, 
spatially processed by a TX spatial processor 392 (if present at user terminal 120), 
multiplexed with pilot symbols, conditioned by one or more modulators 354, and 
transmitted via one or more antennas 352 to access point HOx. 
[0092] At access point HOx, the transmitted uplink signals are received by antennas 

324, demodulated by demodulators 322, and processed by an RX spatial processor 340 
and an RX data processor 342 in a complementary manner to that performed at user 
terminals 120. The recovered feedback information is provided to controller 330 and 
scheduler 334. Scheduler 334 may use the feedback information to perform a number 
of functions such as (1) scheduling a set of user terminals for data transmission on the 
downlink and uplink and (2) assigning the available downlink and uplink resources to 

i 

the scheduled terminals. 

[0093] Controllers 330 and 380 control the operation of various processing units at 

access point llOx and user terminal 120, respectively. For example, controller 380 may 
determine the highest rates supported by the spatial channels on the downlink for user 
terminal 120. Controller 330 may select the rate, payload size, and OFDM symbol size 
for each spatial channel of each scheduled user terminal. 

[0094] The processing at access point llOx and user terminals 120x and 120y for the 

uplink may be the same or different from the processing for the downlink. For clarity, 
the processing for the downlink is described in detail below. 

[0095] FIG. 4 shows a block diagram of an embodiment of TX data processor 310 at 

access point llOx. For this embodiment, TX data processor 310 includes one set of 



WO 2004/038984 



PCT/US2003/034519 



encoder 412, channel interleaver 414, and symbol mapping unit 416 for each of the Ns 
data streams. For each data stream {d m } , where m = 1 ... N s , an encoder 412 receives 
and codes the data stream based on a coding scheme selected for that stream and 
provides code bits. The coding scheme may include CRC, convolutional, Turbo, low 
density parity check (LDPC), block, and other coding, or a combination thereof. A 
channel interleaver 414 interleaves (i.e., reorders) the code bits based on an interleaving 
scheme. A symbol mapping unit 416 maps the interleaved bits based on a modulation 
scheme selected for that stream and provides a stream of data symbols {s m ) . Unit 416 
groups each set of B interleaved bits to form a B-bit binary value, where B > 1 , and 
further maps each B-bit binary value to a specific data symbol based on the selected 
modulation scheme (e.g., QPSK, M-PSK, or M-QAM, where M = 2 B ). The coding and 
modulation for each data stream are performed in accordance with coding and 
modulation controls provided by controller 330. 
[0096] FIG. 5 shows a block diagram of an embodiment of TX spatial processor 320 

and modulators 322a through 322ap at access point HOx. For this embodiment, TX 
spatial processor 32Q includes Ns demultiplexers (Demux) 510a through 510s, Nf TX 
subband spatial processors 520a through 520f, and N ap multiplexers (Mux) 530a through 
530ap. Each demultiplexer 510 receives a respective data symbol stream {s m } from TX 
spatial processor 320, demultiplexes the stream into Nf data symbol substreams for the 
Nf subbands, and provides the Nf substreams to Nf spatial processors 520a through 
520f. Each spatial processor 520 receives Ns data symbol substreams for its subband 
from Ns demultiplexers 510a through 510s, performs transmitter spatial processing on 
these substreams, and provides N ap transmit symbol substreams for the Nap access point 
antennas. Each spatial processor 520 multiplies a data vector s dn (^) with a matrix 
F ap (£) to obtain a transmit vector x^fc). The matrix F ap (£) is equal to (1) a matrix 
V^k) of right eigenvectors of H dn (fc) for the single-user steered mode, (2) the matrix 
F mu (k) for the multi-user steered mode, or (3) the identity matrix I for the single-user 
non-steered mode. 

[0097] Each multiplexer 530 receives N F transmit symbol substreams for its transmit 

antenna from Nf spatial processors 520a through 520f, multiplexes these substreams and 
pilot symbols, and provides a transmit symbol stream {jc,} for its transmit antenna. The 
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pilot symbols may be multiplexed in frequency (i.e., on some subbands), in time (i.e., in 
some symbol periods), and/or in code space (i.e., with an orthogonal code). N ap 
multiplexers 530a through 530ap provide N ap transmit symbol streams {*,.} , for 

j = 1 ... , for Nap antennas 324a through 324ap. 

[0098] For the embodiment shown in FIG. 5, each modulator 322 includes an inverse 

fast Fourier transform (IFF!) unit 542, a cyclic prefix generator 544, and a TX RF unit 
546. IFFT unit 542 and cyclic prefix generator 544 form an OFDM modulator. Each 
modulator 322 receives a respective transmit symbol stream {x ; } from TX spatial 

processor 320 and groups each set of Nf transmit symbols for the Nf subbands. IFFT 
unit 542 transforms each set of Nf transmit symbols to the time domain using an Nf- 
point inverse fast Fourier transform and provides a corresponding transformed symbol 
that contains Nf chips. Cyclic prefix generator 544 repeats a portion of each 
transformed symbol to obtain a corresponding OFDM symbol that contains N F + N cp 

chips. The repeated portion (i.e., the cyclic prefix) ensures that the OFDM symbol 
retains its orthogonal properties in the presence of multipath delay spread caused by 
frequency selective fading. TX RF unit 546 receives and conditions the OFDM symbol 
stream from generator 544 to generate a downlink modulated signal. Nap downlink 
modulated signals are transmitted from Nap antennas 324a through 324ap, respectively. 
[0099] FIG. 6 shows a block diagram of an embodiment of demodulators 354a through 

354ut and RX spatial processor 360y for multi-antenna user terminal 120y. At user 
terminal 120y, Nut antennas 352a through 352ut receive the N^ modulated signals 
transmitted by access point HOx and provide N ut received signals to N ut demodulators 
354a through 354ut, respectively. Each demodulator 354 includes an RX RF unit 612, a 
cyclic prefix removal unit 614, and a fast Fourier transform (FFT) unit 616. Units 614 
and 616 form an OFDM demodulator. Within each demodulator 354, RX RF unit 612 
receives, conditions, and digitizes a respective received signal and provides a stream of 
chips. Cyclic prefix removal unit 614 removes the cyclic prefix in each received 
OFDM symbol to obtain a received transformed symbol. FFT unit 616 then transforms 
each received transformed symbol to the frequency domain with an i\fa-point fast 
Fourier transform to obtain Nf received symbols for the Nf subbands. FFT unit 616 
provides a stream of received symbols to RX spatial processor 360y and received pilot 
symbols to channel estimator 378y. 
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[00100] For the embodiment shown in FIG. 6, RX spatial processor 360y includes N ut 
demultiplexers 630a through 630ut for the Nut antennas at user terminal 120y, N? RX 
subband spatial processors 640a through 640f and Nf scaling units 642a through 642f 
for the N F subbands, and N s multiplexers 650a through 650s for the N s data streams. 
RX spatial processor 360y obtains N ut received symbol streams {>;}, for f = 1 ... N ut , 
from demodulators 354a through 354ut. Each demultiplexer 630 receives a respective 
received symbol stream {/;}, demultiplexes the stream into Nf received symbol 
substreams for the N F subbands, and provides the N F substreams to N F spatial processors 
640a through 640f. Each spatial processor 640 obtains N ut received symbol substreams 
for its subband from N ut demultiplexers 630a through 630ut, performs receiver spatial 
processing on these substreams, and provides Ns detected symbol substreams for its 
subband. Each spatial processor 640 multiplies a received vector r dn (/:) with a matrix 
M^k) to obtain a detected symbol vector s_^(k) . The matrix M^k) is equal to (1) a 
matrix U£(jfc) of left eigenvectors of H^fc) for the single-user steered mode or (2) the 
matrix M ccmi (k) , M mmse (k) , or some other matrix for the single-user non-steered mode. 

[00101] Each scaling unit 642 receives Ns detected symbol substreams for its subband, 
scales these substreams, and provides Ns recovered data symbol substreams for its 
subband. Each scaling unit 642 performs the signal scaling of the detected symbol 
vector 1^ (it) with a diagonal matrix D'J^fc) and provides the recovered data symbol 
vector ^(ifc). Each multiplexer 650 receives and multiplexes N F recovered data 
symbol substreams for its data stream from N F scaling units 642a through 642f and 
provides a recovered data symbol stream. Ns multiplexers 650a through 650s provide 
Ns recovered data symbol streams {s m } , for m = 1 ... N s . 

[00102] FIG. 7 shows a block diagram of an embodiment of RX data processor 370y at 
user terminal 120y. RX data processor 370y includes one set of symbol demapping unit 
712, channel deinterleaver 714, and decoder 716 for each of the N s data streams. For 
each recovered data symbol stream {s m } , where m = 1 ... N s , a symbol demapping unit 
712 demodulates the recovered data symbols in accordance with the modulation scheme 
used for that stream and provides demodulated data. A channel deinterleaver 714 
deinterleaves the demodulated data in a manner complementary to the interleaving 
performed on that stream by access point HOx. A decoder 716 then decodes the 
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deinterleaved data in a manner complementary to the encoding performed by access 
point HOx on that stream. For example, a Turbo decoder or a Viterbi decoder may be 
used for decoder 716 if Turbo or convolutional coding, respectively, is performed at 
access point 11 Ox. Decoder 716 provides a decoded packet for each received data 
packet. Decoder 716 further checks each decoded packet to determine whether the 
packet is decoded correctly or in error and provides the status of the decoded packet. 
The demodulation and decoding for each recovered data symbol stream are performed 
in accordance with demodulation and decoding controls provided by controller 380y. 

[00103] FIG. 8 shows a block diagram of an RX spatial processor 360z and an RX data 
processor 370z, which implement the SIC technique. RX spatial processor 360z and 
RX data processor 370z implement Ns successive (i.e., cascaded) receiver processing 
stages for Ns data symbol streams. Each of stages 1 to N s -1 includes a spatial 
processor 810, an interference canceller 820, an RX data stream processor 830, and a 
TX data stream processor 840. The last stage includes only a spatial processor 810s and 
an RX data stream processor 830s. Each RX data stream processor 830 includes a 
symbol demapping unit 712, a channel deinterleaver 714, and a decoder 716, as shown 
in FIG. 7. Each TX data stream processor 840 includes an encoder 412, a channel 
interleaver 414, and a symbol mapping unit 416, as shown in FIG. 4. 

[00104] For stage 1, spatial processor 810a performs receiver spatial processing on the 
N ut received symbol streams and provides one recovered data symbol stream {S^h 
where the subscript j\ denotes the access point antenna used to transmit the data symbol 
stream [s h }. RX data stream processor 830a demodulates, deinterleaves, and decodes 

the recovered data symbol stream {s h } and provides a corresponding decoded data 
stream {d h }, TX data stream processor 840a encodes, interleaves, and modulates the 
decoded data stream {d j% } in the same manner performed by access point HOx for that 
stream and provides a remodulated symbol stream Interference canceller 820a 

performs spatial processing on the remodulated symbol stream } in the same manner 
(if any) performed by access point HOx and further processes the result with the 
channel response matrix H dIl (^) to obtain N ut interference components due to the data 
symbol stream {s, }. The N ut interference components are subtracted from the N M 
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received symbol streams to obtain N ut modified symbol streams, which are provided to 
stage 2. 

[00105] Each of stages 2 through N s - 1 performs the same processing as stage 1, albeit 
on the N ut modified symbol streams from the preceding stage instead of the N ut received 
symbol streams. The last stage performs spatial processing and decoding on the 
modified symbol streams from stage N s -1 and does not perform interference 

estimation and cancellation. 
[00106] Spatial processors 810a through 810s may each implement the CCNfl, MMSE, 
or some other receiver processing technique. Each spatial processor 810 multiplies an 
input (received or modified) symbol vector r^(£) with a matrix M*(&) t0 obtain a 
detected symbol vector l^(fc) , selects and scales one of the detected symbol streams, 
and provides the scaled symbol stream as the recovered data symbol stream for that 
stage. The matrix M^(Jk) is derived based on a reduced channel response matrix 
H^(fc) for the stage. 

[00107] The processing units at access point llOx and user terminal 120y for the uplink 
may be implemented as described above for the downlink. TX data processor 390y and 
TX spatial processor 392y may be implemented with TX data processor 310 in FIG. 4 
and TX spatial processor 320 in FIG. 5, respectively. RX spatial processor 340 may be 
implemented with RX spatial processor 360y or 360z, and RX data processor 342 may 
be implemented with data processor 370y or 370z. 

[00108] For single-antenna user terminal 120x, RX spatial processor 360x performs 
coherent demodulation of one received symbol stream with channel estimates to obtain 
one recovered data symbol stream. 

A. Channel Estimation 

[00109] The channel response of the downlink and uplink may be estimated in various 
manners such as with a MEMO pilot or a steered pilot. For a TDD MDGMO system, 
certain techniques may be used to simplify the channel estimation. 

[00110] For the downlink, access point 1 lOx can transmit a MMO pilot to user terminals 
120. The MIMO pilot comprises N ap pilot transmissions from Nap access point 
antennas, with the pilot transmission from each antenna being "covered" with a 
different orthogonal sequence (e.g., a Walsh sequence). Covering is a process whereby 
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a given modulation symbol (or a set of L modulation symbols with the same value) to be 
transmitted is multiplied by all L chips of an L-chip orthogonal sequence to obtain L 
covered symbols, which are then transmitted. The covering achieves orthogonality 
among the Nap pilot transmissions sent from the N ap access point antennas and allows 
the user terminals to distinguish the pilot transmission from each antenna. 
[00111] At each user terminal 120, channel estimator 378 "decovers" the received pilot 
symbols for each user terminal antenna i with the same N ap orthogonal sequences used 
by access point HOx for the N ap antennas to obtain estimates of the complex channel 
gain between user terminal antenna i and each of the Nap access point antennas. 
Decovering is complementary to covering and is a process whereby received (pilot) 
symbols are multiplied by the L chips of the L-chip orthogonal sequence to obtain L 
decovered symbols, which are then accumulated to obtain an estimate of the transmitted 
(pilot) symbol. Channel estimator 378 performs the same pilot processing for each 
subband used for pilot transmission. If pilot symbols are transmitted on only a subset of 
the N F subbands, then channel estimator 378 can perform interpolation on the channel 
response estimates for subbands with pilot transmission to obtain channel response 
estimates for subbands without pilot transmission. For single-antenna user terminal 
120x, channel estimator 378x provides estimated downlink channel response vectors 
h dn (jt), for Jk = l ... N F , for the single antenna 352. For multi-antenna user terminal 
120y, channel estimator 378y performs the same pilot processing for all N* antennas 
352a through 352ut and provides estimated downlink channel response matrices 
H^fc) , for k = 1 ... N F . Each user terminal 120 can also estimate the noise variance 
for the downlink based on the received pilot symbols and provides the downlink noise 
estimate, (7^. 

[00112] For the uplink, multi-antenna user terminal 120y can transmit a MMO pilot that 

can be used by access point HOx to estimate the uplink channel response H^fc) for 

user terminal 120y. Single-antenna user terminal 120x can transmit a pilot from its 
single antenna. Multiple single-antenna user terminals 120 can transmit orthogonal 
pilots simultaneously on the uplink, where orthogonality may be achieved in time 
and/or frequency. Time orthogonality can be obtained by having each user terminal 
cover its uplink pilot with a different orthogonal sequence assigned to the user terminal. 
Frequency orthogonality can be obtained by having each user terminal transmit its 



WO 2004/038984 



PCTVUS2003/034519 



31 

uplink pilot on a different set of subbands. The simultaneous uplink pilot transmissions 
from multiple user terminals should be approximately time-aligned at access point 120x 
(e.g., time-aligned to within the cyclic prefix). 

[00113] For a TDD MIMO system, a high degree of correlation normally exists between 
the channel responses for the downlink and uplink since these links share the same 
frequency band. However, the responses of the transmit/receive chains at the access 
point are typically not the same as the responses of the transmit/receive chains at the 
user terminal. If the differences are determined and accounted for via calibration, then 
the overall downlink and uplink channel responses may be assumed to be reciprocal 
(i.e., transpose) of each other. 

[00114] FIG- 9 shows the transmit/receive chains at access point HOx and user terminal 
120y. At access point HOx, the transmit path is modeled by an N^xN^ matrix 

T ap (fc) and the receive path is modeled by an N^xN^ matrix R ap (fc). At user 
terminal 120y, the receive path is modeled by an N ta xN m matrix £*(£) and the 
transmit path is modeled by an N ut xN ut matrix T m (fc). The received symbol vectors 
for the dbwnlink and uplink for each subband may be expressed as: 

r^(k) = RJtM^WxJfc) , and Eq (33) 

r lip (/:) = R ap WH r (^)T ut ^)x up « , 

where " r " denotes the transpose. Equation (34) assumes that the downlink and uplink 
are transpose of one another. The "effective" downlink and uplink channel responses, 
H^Ofc) and H eop (fe), for each subband include the responses of the transmit and 
receive chains and may be expressed as: 

H cdn W = R ot (^)H(fc)T flp (A:) and H^*) = R ap (*)H r (*)!* (*) . Eq(34) 

The effective downlink and uplink channel responses are not reciprocal of one other 
(i.e., H een (^)^He up (^)) if the responses of the downlink and uplink transmit/receive 

chains are not equal to each other. 
[00115] Access point HOx and user terminal 120y can perform calibration to obtain 

correction matrices K ap (fc) and K ut (fc) for each subband, which may be expressed as: 
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K ap (*) = :L>)E a p(*) and K ttl (*) = i; l WR ul (*) . Eq(35) 

The correction matrices may be obtained by transmitting MMO pilots on both the 
downlink and uplink and deriving the correction matrices using MMSE criterion or 
some other techniques. The correction matrices K ap (£) and K^k) are applied at 
access point llOx and user terminal 120y, respectively, as shown in FIG. 9. The 
"calibrated" downlink and uplink channel responses, H cdn (fc) and H^Cfc), are then 
reciprocal of one another and may be expressed as: 

= H*(«KJ« =HL(*) . Eq(36) 

[00116] The singular value decomposition of the calibrated uplink and downlink channel 

response matrices, H CTp (fc) and H cdn (fc) , for each subband may be expressed as: 

H c ^k) = V ap (k)mY"(k) • and Eq(37) 
H cda (fe) = Y; t (fc)S(fc)Uf p W . 

As shown in equation set (38), the matrices V^(fc) and U^fc) of left and right 
eigenvectors of H cdo (/0 are the complex conjugate of the matrices V ut (fc) and U ap (fc) 
of right and left eigenvectors of H cup (fc). The matrix U ap (fc) can be used by access 
point 1 lOx for both transmit and receive spatial processing. The matrix V m (fc) can be 
used by user terminal 120y for both transmit and receive spatial processing. 
[001171 Because of the reciprocal nature of the MIMO channel for the TDD MIMO 

system, and after calibration has been performed to account for the differences in the 
transmit/receive chains, the singular value decomposition only needs to be performed by 
either user terminal 120y or access point llOx. If performed by user terminal 120y, 
then the matrices V m (ifc), for k =1 ... N F7 are used for spatial processing at the user 
terminal and the matrix U ap (*) , for k = 1 ... N F , may be provided to the access point in 
either a direct form (e.g., by sending entries of the matrices U ap (fc) ) or an indirect form 
(e.g., via a steered pilot). In actuality, user terminal 120y can only obtain d^W, 
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which is an estimate of H cdn (*), and can only derive YA k ) . and U ap (^), which 

are estimates of V w (Jfc) , I(fc) and V^Qk) , respectively. For simplicity, the description 

herein assumes channel estimation without eiTors. 
[00118] An uplink steered pilot sent by user terminal 120y may be expressed as: 

*^(k) = K^k)y_ M {k)p{k) , Eq(38) 

where y^ m (k) is the m-th column of V^fc) and p(k) is the pilot symbol. The received 
uplink steered pilot at access point HOx may be expressed as: 

Equation (40) indicates that access point HOx can obtain the matrix U ap (fc) , one vector 

at a time, based on the uplink steered pilot from user terminal 120y. 

[00119] A complementary process may also be performed whereby user terminal 120y 
transmits a MIMO pilot on the uplink, and access point 1 lOx performs singular value 
decomposition and transmits a steered pilot on the downlink. Channel estimation for 
the downlink and uplink may also be performed in other manners. 

[00120] At each user terminal 120, channel estimator 378 can estimate the downlink 
channel response (e.g., based on a MIMO pilot or a steered pilot sent by access point 
11 Ox) and provide downlink channel estimates to controller 380. For single-antenna 
user terminal 120x, controller 380x can derive the complex channel gains used for 
coherent demodulation. For multi-antenna user terminal 120y, controller 380y can 
derive the matrix M ut (fc) used for receive spatial processing and the matrix F ul (fc) 
used for transmit spatial processing based on the downlink channel estimates. At access 
point HOx, channel estimator 328 can estimate the uplink channel response (e.g., based 
on a steered pilot or a MIMO pilot sent by user terminal 120) and provide uplink 
channel estimates to controller 380. Controller 380 can derive the matrix F ap (fc) used 

for transmit spatial processing and the matrix M ap (fc) used for receive spatial 

processing based on the uplink channel estimates. 
[00121] FIG. 9 shows the spatial processing at access point HOx and user terminal 120y 

for the downlink and uplink for one subband k. For the downlink, within TX spatial 
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processor 320 at access point 110x, the data vector s^Cfc) is first multiplied with the 
matrix F ap (&) by a unit 910 and further multiplied with the correction matrix K^ik) 
by a unit 912 to obtain the transmit vector x^ik) . The vector x^ik) is processed by a 
transmit chain 914 within modulators 322 and transmitted over the M1MO channel to 
user terminal 120y. Units 910 and 912 perform the transmit spatial processing for the 
downlink and may be implemented within TX subband spatial processor 520 in FIG. 5. 

[00122] At user terminal 120y, the downlink signals are processed by a receive chain 954 
within demodulators 354 to obtain the receive vector r ta (k). Within RX spatial 
processor 360y, the receive vector r^Cfc) is first multiplied with the matrix M^(k) by 
a unit 956 and further scaled with the inverse diagonal matrix D*(fc) by a unit 958 to 
obtain the vector (k) , which is an estimate of the data vector (fc) . Units 956 and 
958 perform the receive spatial processing for the downlink and may be implemented 
within RX subband spatial processor 640 in FIG. 6. 

[00123] For the uplink, within TX spatial processor 392y at user terminal 120y, the data 
vector s up (£) is first multiplied with the matrix F^Cfc) by a unit 960 and further 

multiplied with the correction matrix K nl (k) by a unit 962 to obtain the transmit vector 
Xup(fc) . The vector x up (fc) is processed by a transmit chain 964 within modulators 354 
and transmitted over the MIMO channel to access point HOx. Units 960 and 962 
perform the transmit spatial processing for the uplink. 
[00124] At access point HOx, the uplink signals are processed by a receive chain 924 
within demodulators 322 to obtain the receive vector r^fc). Within RX spatial 

processor 340, the receive vector r up (fc) is first multiplied with the matrix M ap (fc) by a 
unit 926 and further scaled with the inverse diagonal matrix I[^(k) by a unit 928 to 
obtain the vector s^(k) , which is an estimate of the data vector s up (&) . Units 926 and 
928 perform the receive spatial processing for the uplink. 

B. Spatial Processing for TDD MIMO System 
[00125] Table 3 summarizes exemplary pilot transmission and spatial processing 

performed by the access point and the user terminals for data transmission on the 
downlink and uplink for various spatial multiplexing modes in the TDD MIMO system. 
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For the single-user steered mode, the access point transmits a MMO pilot to allow the 
user terminal to estimate the downlink channel response. The user terminal transmits a 
steered pilot to allow the access point to estimate the uplink channel response. The 
access point performs transmit and receive spatial processing with V^ik). The user 

terminal performs transmit and receive spatial processing with V^fc) . 
[00126] For the single-user non-steered mode, for downlink data transmission, the access 
point transmits a MIMO pilot from all antennas and a data symbol stream from each 
antenna. The user terminal estimates the downlink channel response with the MMO 
pilot and performs receiver spatial processing using the downlink channel estimates. 
The complementary processing occurs for uplink data transmission. 



Table 3 



Spatial 
Multiplexing 
Mode 


Downlink Data 
Transmission 


Uplink Data 
Transmission 


Single-User 
Steered 


AP transmits MIMO pilot 
UT transmits steered pilot 
AP transmits data with U np (£) 

UT receives data with V ut (fc) 


AP transmits MMO pilot 
UT transmits steered pilot 
UT transmits data with V^fc) 
AP receives data with U ap (fc) 


Single-User 
Non-Steered 


AP transmits MMO pilot 
AP transmits data from each 

antenna 
UT uses CCMI, MMSE, etc. 


UT transmits MMO pilot 
UT transmits data from each 

antenna 
AP uses CCMI, MMSE, etc. 


Multi-User 
Steered 


UTs transmit orthogonal pilot 
AP transmits steered data 
AP transmits steered pilot 

UTs receive with steered pilot 


AP transmits MMO pilot 
UTs transmit steered pilot 
UTs transmit steered data 
AP uses CCMI, MMSE, etc. 


Multi-User 
Non-Steered 


AP transmits MMO pilot 
UTs send rate for each AP antenna 
AP transmits data from each 

antenna 
UTs use CCMI, MMSE, etc. 


UTs transmit orthogonal pilot 
AP selects compatible UTs 

UTs transmits data from each 

antenna 
AP uses CCMI, MMSE, etc. 



[00127] For the multi-user steered mode, for downlink data transmission to single- 
antenna and/or multi-antenna user terminals, the user terminals transmit orthogonal 
pilots on the uplink to allow the access point to estimate the downlink channel response. 
A single-antenna user terminal transmits an unsteered pilot, and a multi-antenna user 
terminal transmits a steered pilot. The access point derives downlink steering vectors 
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based on the orthogonal uplink pilots, and uses the steering vectors to transmit steered 
pilots and steered data symbol streams to the selected user terminals. Each user 
terminal uses the steered pilot to receive the steered data symbol stream sent to the user 
terminal. For uplink data transmission from multi-antenna user terminals, the access 
point transmits a MMO pilot. Each multi-antenna user terminal transmits a steered 
pilot and a steered data symbol stream on the uplink. The access point performs 
receiver spatial processing (e.g., CCMI, MMSE, and so on) to recover the data symbol 
streams. 

[00128] For the multi-user non-steered mode, for downlink data transmission to multi- 
antenna user terminals, the access point transmits a MIMO pilot on the downlink. Each 
user terminal determines and sends back the rate it can receive from each access point 
antenna. The access point selects a set of user terminals and transmits data symbol 
streams for the selected user terminals from the access point antennas. Each multi- 
antenna user terminal performs receiver spatial processing (e.g., CCMI, MMSE, and so 
on) to recover its data symbol stream. For uplink data transmission from single-antenna 
and/or multi-antenna user terminals, the user terminals transmit orthogonal (unsteered) 
pilots on the uplink. The access point estimates the uplink channel response based on 
the uplink pilots and selects a set of compatible user terminals. Each selected user 
terminal transmits a data symbol stream from a user terminal antenna. The access point 
performs receiver spatial processing (e.g., CCMI, MMSE, and so on) to recover the data 
symbol streams. 

C, Rate Selection 

[00129] Each data stream for the downlink and uplink is transmitted on a wideband 
spatial channel m using one of the spatial multiplexing modes. Each data stream is also 
transmitted at a rate that is selected such that the target level of performance (e.g., 1 
percent packet error rate (PER)) can be achieved for that stream. The rate for each data 
stream can be determined based on the SNR achieved at the receiver for that stream 
(i.e., the received SNR), where the SNR is dependent on the spatial processing 
performed at the transmitter and receiver, as described above. 

[00130] In an exemplary rate selection scheme, the determine the rate for wideband 

spatial channel m, an SNR estimate, y m (k) 7 (e.g., in units of dB) for each subband k of 
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the wideband spatial channel is first obtained, as described above. An average SNR, 
y , is then computed for wideband spatial channel m, as follows: 



The variance of the SNR estimates, a* m , is also computed as follows: 

An SNR back-off factor, y b0im9 is determined based on a function F(y avg ^a^) of the 
average SNR and the SNR variance. For example, the function F(Y avg 0>tf m ) = K b ' a r m 
may be used, where K b is a scaling factor that may be selected based on one or more 
characteristics of the MIMO system such as the interleaving, packet size, and/or coding 
scheme used for the data stream. The SNR back-off factor accounts for variation in 
SNRs across the wideband spatial channel. An operating SNR, y op>m> for wideband 
spatial channel m is next computed, as follows: 

Yopjn ~ Yavgjn ~ Ybo.m ' (42) 

The rate for the data stream is then determined based on the operating SNR. For 
example, a look-up table (LOT) may store a set of rates supported by the MIMO system 
and their required SNRs. The required SNR for each rate may be determined by 
computer simulation, empirical measurement, and so 'on, and based on an assumption of 
an AWGN channel. The highest rate in the look-up table with a required SNR that is 
equal to or lower than the operating SNR is selected as the rate for the data stream sent 
on wideband spatial channel m. 
[00131] Various other rate selection schemes may also be used. 

D. Closed-Loop Rate Control 
[00132] Closed-loop rate control may be used for each of the data streams transmitted on 

multiple wideband spatial channels. Closed-loop rate control may be achieved with one 
or multiple loops. 
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[00133] FIG. 10 shows a block diagram of an embodiment of a closed-loop rate control 
mechanism 1000, which comprises an inner loop 1010 that operates in conjunction with 
an outer loop 1020. Inner loop 1010 estimates the channel conditions and determines 
the rate supported by each wideband spatial channel. Outer loop 1020 estimates the 
quality of the data transmission received on each wideband spatial channel and adjusts 
the operation of the inner loop accordingly. For simplicity, the operation of loops 1010 
and 1020 for one downlink wideband spatial channel m is shown in FIG. 10 and 
described below. 

[00134] For inner loop 1010, channel estimator 378 at user terminal 120 estimates 

wideband spatial channel m and provides channel estimates (e.g., channel gain estimates 
and noise variance estimate). A rate selector 1030 within controller 380 determines the 
rate supported by wideband spatial channel m based on (1) the channel estimates from 
channel estimator 378, (2) an SNR back-off factor and/or a rate adjustment for 
wideband spatial channel m from a quality estimator 1032, and (3) a look-up table 
(LUT) 1036 of rates supported by the MIMO system and their required SNRs. The 
supported rate for wideband spatial channel m is sent by controller 380 to access point 
110. At access point 110, controller 330 receives the supported rate for wideband 
spatial channel m and determines the data rate, coding, and modulation controls for the 
data stream to be sent on this spatial channel. The data stream is then processed in 
accordance with these controls by TX data processor 310, spatially processed and 
multiplexed with pilot symbols by TX spatial processor 320, conditioned by modulators 
322, and transmitted to user terminal 120. 

[00135] Outer loop 1020 estimates the quality of the decoded data steam received on 

wideband spatial channel m and adjusts the operation of inner loop 1010. The received 
symbols for wideband spatial channel m are spatially processed by RX spatial processor 
360 and further processed by RX data processor 370. RX data processor 370 provides 
the status of each packet received on wideband spatial channel m and/or decoder metrics 
to quality estimator 1032. Outer loop 1020 can provide different types of information 
(e.g., SNR back-off factor, a rate adjustment, and so on) used to control the operation of 
inner loop 1010. 

[00136] Closed-loop rate control described above may thus be performed independently 

for each downlink and uplink wideband spatial channel, which can correspond to (1) a 
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wideband eigenmode, for the single-user steered mode, or (2) a transmit antenna, for the 
single-user and multi-user non-steered modes. 

E. Scheduling User Terminals 

[00137] FIG. 11 shows a block diagram of an embodiment of controller 330 and 
scheduler 334 for scheduling user terminals for data transmission on the downlink and 
uplink. Within controller 330, a request processor 1110 receives access requests 
transmitted by user terminal 120 on the RACH and possibly access requests from other 
sources. These access requests are for data transmission on the downlink and/or uplink. 
Request processor 1110 processes the received access requests and provides the 
identities (IDs) and the status of all requesting user terminals. The status for a user 
terminal may indicate the number of antennas available at the terminal, whether the 
terminal is calibrated, and so on. 

[00138] A rate selector 1120 receives channel estimates from channel estimator 328 and 

determines the rates supported by the downlink and/or uplink wideband spatial channels 
for the requesting user terminals, as described above. For the downlink, each user 
terminal 120 can determine the rate supported by each of its wideband spatial channels, 
as described above. The supported rate is the maximum rate that may be used for data 
transmission on the wideband spatial channel to achieve the target level of performance. 
Each user terminal 120 can send the supported rates for all of its downlink wideband 
spatial channels to access point 110, e.g., via the RACH. Alternatively, access point 
1 10 can determine the supported rates for the downlink wideband spatial channels if (1) 
the downlink and uplink are reciprocal and (2) access point 110 is provided with the 
noise variance or noise floor at user terminal 120. For the uplink, access point 110 can 
determine the supported rate for each wideband spatial channel for each requesting user 
terminal 120. 

[00139] A user selector 1140 selects different sets of one or more user terminals, from 
among all of the requesting user terminals, for possible data transmission on the 
downlink and/or uplink. The user terminals may be selected based on various criteria 
such as system requirements, user terminal capabilities and supported rates, user 
priority, the amount of data to send, and so on. For the multi-user spatial multiplexing 
modes, the user terminals for each set may also be selected based on their channel 
response vectors. 
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[00140] A mode selector 1130 selects the particular spatial multiplexing mode to use for 

each set of user terminals based on the operating state and capabilities of the user 
terminals in the set and possibly other factors. For example, the single-user steered 
mode may be used for a "calibrated" multi-antenna user terminal that has performed 
calibration so that the channel response for one link (e.g., downlink) can be estimated 
based on a (e.g., steered) pilot received via the other link (e.g., uplink). The single-user 
non-steered mode may be used for an "uncalibrated" multi-antenna user terminal that 
has not performed calibration or cannot support the single-user steered mode for any 
reason. The multi-user steered mode may be used for downlink transmission to multiple 
user terminals, each of which is equipped with one or more antennas. The multi-user 
non-steered mode may be used for uplink transmission by multiple user terminals. 

[00141] Scheduler 334 receives the sets of user terminals from user selector 1140, the 

selected spatial multiplexing mode for each user terminal set from mode selector 1130, 
and the selected rates for each user terminal set from rate selector 1120. Scheduler 334 
schedules the user terminals for data transmission on the downlink and/or uplink. 
Scheduler 334 selects one or more sets of user terminals for data transmission on the 
downlink and one or more sets of user terminals for data transmission on the uplink for 
each TDD frame. Each set includes one or more user terminals and is scheduled for 
data transmission concurrently in a designated transmission interval within the TDD 
frame. 

[00142] Scheduler 334 forms an information element (IE) for each user terminal 

scheduled for data transmission on the downlink and/or uplink. Each information 
element includes (1) the spatial multiplexing mode to use for data transmission, (2) the 
rate to use for the data stream sent on each wideband spatial channel, (3) the start and 
the duration of the data transmission, and (4) possibly other information (e.g., the type 
of pilot being transmitted along with the data transmission). Scheduler 334 sends the 
information elements for all scheduled user terminals via the FCCH. Each user terminal 
processes the FCCH to recover its information element, and thereafter receives a 
downlink transmission and/or sends an uplink transmission in accordance with the 
received scheduling information. 

[00143] FIG. 11 shows an embodiment of the scheduling of usfcr terminals for data 

transmission when multiple spatial multiplexing modes are supported. The scheduling 
may be performed in other manners, and this is within the scope of the invention. 
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[00144] FIG. 12 shows a flow diagram of a process 1200 for scheduling user terminals 
for data transmission in MMO system 100. A set of least one user terminal is selected 
for data transmission on the downlink and/or uplink (block 1212). A spatial 
multiplexing mode is selected for the user terminal set from among multiple spatial 
multiplexing modes supported by the system (block 1214). Multiple rates are also 
selected for multiple data streams to be transmitted via multiple spatial channels for the 
user terminal set (block 1216). The user terminal set is scheduled for data transmission 
on the downlink and/or uplink with the selected rates and the selected spatial 
multiplexing mode (block 1218). 

[00145] FIG. 13 shows a flow diagram of a process 1300 for transmitting data on the 

downlink in MIMO system 100. Process 1300 may be performed by access point HOx. 
A first plurality of data streams are coded and modulated in accordance with a first 
plurality of rates to obtain a first plurality of data symbol streams (block 1312). For the 
single-user steered mode, the first plurality of data symbol streams are spatially 
processed with a first plurality of steering vectors to obtain a first plurality of transmit 
symbol streams for transmission from multiple antennas to a first user terminal in a first 
transmission interval (block 1314). The first plurality of steering vectors are derived 
such that the first plurality of data streams are transmitted on orthogonal spatial 
channels to the first user terminal. A second plurality of data streams are coded and 
modulated in accordance with a second plurality of rates to obtain a second plurality of 
data symbol streams (block 1316). For the single-user non-steered mode, the second 
plurality of data symbol streams are provided as a second plurality of transmit symbol 
streams for transmission from the multiple antennas to a second user terminal in a 
second transmission interval (block 1318). A third plurality of data streams are coded 
and modulated to obtain a third plurality of data symbol streams (block 1320). For the 
multi-user steered mode, the third plurality of data symbol streams are spatially 
processed with a second plurality of steering vectors to obtain a third plurality of 
transmit symbol streams for transmission from the multiple antennas to multiple user 
terminals in a third transmission interval (block 1322). The second plurality of steering 
vectors are derived such that the third plurality of data symbol streams are received with 
suppressed crosstalk at the multiple user terminals. 

[00146] FIG- 14 shows a flow diagram of a process 1400 for receiving data on the uplink 

in MMO system 100. Process 1400 may also be performed by access point HOx. 
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Receiver spatial processing is performed on a first plurality of received symbol streams 
in accordance with a first spatial multiplexing mode (e.g., the single-user steered mode) 
to obtain a first plurality of recovered data symbol streams (block 1412). The first 
plurality of recovered data symbol streams are demodulated and decoded in accordance 
with a first plurality of rates to obtain a first plurality of decoded data streams (block 
1414). Receiver spatial processing is performed on a second plurality of received 
symbol streams in accordance with a second spatial multiplexing mode (e.g., a non- 
steered mode) to obtain a second plurality of recovered data symbol streams (block 
1416). The second plurality of recovered data symbol streams are demodulated and 
decoded in accordance with a second plurality of rates to obtain a second plurality of 
decoded data streams, which are estimates of data streams transmitted by one or 
multiple user terminals (block 1418). 

[00147] Each user terminal performs corresponding processes to transmit data on one or 
multiple uplink wideband spatial channels and to receive data on one or multiple 
downlink wideband spatial channels. 

[00148] Data transmission with multiple spatial multiplexing modes, as described herein, 
may be implemented by various means. For example, the processing may be 
implemented in hardware, software, or a combination thereof. For a hardware 
implementation, the processing units used to perform data processing, spatial 
processing, and scheduling at the access point may be implemented within one or more 
application specific integrated circuits (ASICs), digital signal processors (DSPs), digital 
signal processing devices (DSPDs), programmable logic devices (PLDs), field 
programmable gate arrays (FPGAs), processors, controllers, micro-controllers, 
microprocessors, other electronic units designed to perform the functions described 
herein, or a combination thereof. The processing units at a user terminal may also be 
implemented on one or more ASICs, DSPs, and so on. 

[00149] For a software implementation, the processing at the access point and user 
terminal for data transmission with multiple spatial multiplexing modes may be 
implemented with modules (e.g., procedures, functions, and so on) that perform the 
functions described herein. The software codes may be stored in a memory unit (e.g., 
memory unit 332 or 382 in FIG. 3) and executed by a processor (e.g., controller 330 or 
380). The memory unit may be implemented within the processor or external to the 
processor. 
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[00150] Headings are included herein for reference and to aid in locating certain 
sections. These headings are not intended to limit the scope of the concepts described 
therein under, and these concepts may have applicability in other sections throughout 
the entire specification. 

[00151] The previous description of the disclosed embodiments is provided to enable any 
person skilled in the art to make or use the present invention. Various modifications to 
these embodiments will be readily apparent to those skilled in the art, and the generic 
principles defined herein may be applied to other embodiments without departing from 
the spirit or scope of the invention. Thus, the present invention is not intended to be 
limited to the embodiments shown herein but is to be accorded the widest scope 
consistent with the principles and novel features disclosed herein. 



WHAT IS CLAIMED IS: 
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CLAIMS 

L A method of transmitting data in a wireless multiple-access multiple- 
input multiple-output (MMO) communication system, comprising: 

selecting at least one user terminal for data transmission; 

selecting a spatial multiplexing mode, from among a plurality of spatial 
multiplexing modes supported by the system, to use for the at least one user terminal; 

selecting a plurality of rates for a plurality of data streams to be transmitted via a 
plurality of spatial channels of a MIMO channel for the at least one user terminal; and 

scheduling the at least one user terminal for data transmission with the plurality 
of selected rates and the selected spatial multiplexing mode. 

2. The method of claim 1, wherein one user terminal is selected for data 
transmission and the selected spatial multiplexing mode is a steered spatial multiplexing 
mode. 

3 . The method of claim 2, further comprising: 

spatially processing the plurality of data streams with a plurality of steering 
vectors to transmit the plurality of data streams on orthogonal spatial channels to the 
one user terminal. 

4. The method of claim 1, wherein one user terminal is selected for data 
transmission and the selected spatial multiplexing mode is a non-steered spatial 
multiplexing mode. 

5 . The method of claim 4, further comprising: 

providing the plurality of data streams for transmission from a plurality of 
antennas to the one user terminal. 

6. The method of claim 1, wherein a plurality of user terminals are selected 
for data transmission and the selected spatial multiplexing mode is a steered spatial 
multiplexing mode. 
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7. The method of claim 6, further comprising: 

spatially processing the plurality of data streams with a plurality of steering 
vectors to steer the plurality of data streams to the plurality of user terminals. 

8. The method of claim 6, further comprising: 

performing receiver spatial processing on a plurality of received symbol streams 
to obtain estimates of the plurality of data streams transmitted by the plurality of user 
terminals, wherein each data stream is processed with a respective steering vector to 
steer the data stream. 

9. The method of claim 1, wherein a plurality of user terminals are selected 
for data transmission and the selected spatial multiplexing mode is a non-steered spatial 
multiplexing mode. 

10. The method of claim 9, further comprising: 

performing receiver spatial processing on a plurality of received symbol streams 
to obtain estimates of the plurality of data streams transmitted by the plurality of user 
terminals. 

1 1 . The method of claim 9, further comprising: 

providing the plurality of data streams for transmission from a plurality of 
antennas to the plurality of user terminals each having multiple antennas. 

12. The method of claim 1, wherein the MMO system is a time division 
duplex (TDD) system. 

13. The method of claim 12, wherein the selected spatial multiplexing mode 
is a steered spatial multiplexing mode if the at least one user terminal is calibrated and 
downlink channel response is reciprocal of uplink channel response. 

14. The method of claim 12, wherein the selected spatial multiplexing mode 
is a non-steered spatial multiplexing mode if the at least one user terminal is 
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uncalibrated and downlink channel response is not reciprocal of uplink channel 
response. 

1 5. The method of claim 1 , wherein the selecting a plurality of rates includes 
estimating signal-to-noise-and-interference ratios (SNRs) of the plurality of 

spatial channels, and 

selecting the plurality of rates based on the estimated SNRs of the plurality of 
spatial channels. 

16. An apparatus in a wireless multiple-access multiple-input multiple- 
output (MMO) communication system, comprising: 

a terminal selector operative to select at least one user terminal for data 
transmission; 

a mode selector operative to select a spatial multiplexing mode, from among a 
plurality of spatial multiplexing modes supported by the system, to use for the at least 
one user terminal; 

a rate selector operative to select a plurality of rates for a plurality of data 
streams to be transmitted via a plurality of spatial channels of a MIMO channel for the 
at least one user terminal; and 

a scheduler operative to schedule the at lea$t one user terminal for data 
transmission with the plurality of selected rates and the selected spatial multiplexing 
mode. 

17. The apparatus of claim 16, further comprising: 

a transmit spatial processor operative to spatially process the plurality of data 
streams in accordance with the selected spatial multiplexing mode to obtain a plurality 
of transmit symbol streams for transmission from a plurality of antennas to the at least 
one user terminal. 

18. The apparatus of claim 16, further comprising: 

a receive spatial processor operative to spatially process a plurality of received 
symbol streams in accordance with the selected spatial multiplexing mode to obtain 
estimates of the plurality of data streams transmitted by the at least one user terminal. 
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19. An apparatus in a wireless multiple-access multiple-input multiple- 
output (MIMO) communication system, comprising: 

means for selecting at least one user terminal for data transmission; 

means for selecting a spatial multiplexing mode, from among a plurality of 
spatial multiplexing modes supported by the system, to use for the at least one user 
terminal; 

means for selecting a plurality of rates for a plurality of data streams to be 
transmitted via a plurality of spatial channels of a MIMO channel for the at least one 
user terminal; and 

means for scheduling the at least one user terminal for data transmission with the 
plurality of selected rates and the selected spatial multiplexing mode. 

20. The apparatus of claim 19, further comprising: 

means for spatially processing the plurality of data streams in accordance with 
the selected spatial multiplexing mode to obtain a plurality of transmit symbol streams 
for transmission from a plurality of antennas to the at least one user terminal. 

21 . The apparatus of claim 19, further comprising: 

means for spatially processing a plurality of received symbol streams in 
accordance with the selected spatial multiplexing mode to obtain estimates of the 
plurality of data streams transmitted by the at least one user terminal. 

22. A method of transmitting data in a wireless multiple-access multiple- 
input multiple-output (MIMO) communication system, comprising: 

selecting a first user terminal for data transmission in a first transmission 
interval; 

selecting a first spatial multiplexing mode to use for the first user terminal; 
selecting a second user terminal for data transmission in a second transmission 
interval; 

selecting a second spatial multiplexing mode to use for the second user terminal; 
scheduling the first user terminal for data transmission in the first transmission 
interval with the first spatial multiplexing mode; and 
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scheduling the second user terminal for data transmission in the second 
transmission interval with the second spatial multiplexing mode. 

23. The method of claim 22, wherein the first spatial multiplexing mode is a 
steered spatial multiplexing mode and the second spatial multiplexing mode is a non- 
steered spatial multiplexing mode. 

24. The method of claim 23, further comprising: 

spatially processing a first plurality of data streams with a plurality of steering 
vectors to transmit the first plurality of data streams on orthogonal spatial channels of a 
MIMO channel for the first user terminal; and 

providing a second plurality of data streams for transmission from a plurality of 
antennas to the second user terminal. 

25 . The method of claim 23, further comprising: 

performing receiver spatial processing on a first plurality of received symbol 
streams with a plurality of eigenvectors to obtain estimates of a first plurality of data 
streams transmitted by the first user terminal; and 

performing receiver spatial processing on a second plurality of received symbol 
streams in accordance with a spatial filter to obtain estimates of a second plurality of 
data streams transmitted by the second user terminal. 

26. The method of claim 23, further comprising: 

selecting a first plurality of rates for a first plurality of data streams to be 
transmitted via a first plurality of spatial channels of a first MMO channel for the first 
user terminal; and 

selecting a second plurality of rates for a second plurality of data streams to be 
transmitted via a second plurality of spatial channels of a second MEMO channel for the 
second user terminal, and 

wherein the first user terminal is further scheduled with the first plurality of rates 
and the second user terminal is scheduled with the second plurality of rates. 
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27. An apparatus in a wireless multiple-access multiple-input multiple- 
output (MMO) communication system, comprising: 

a user selector operative to select a first user terminal for data transmission in a 
first transmission interval and to select a second user terminal for data transmission in a 
second transmission interval; 

a mode selector operative to select a first spatial multiplexing mode to use for 
the first user terminal and to select a second spatial multiplexing mode to use for the 
second user terminal; and 

a scheduler operative to schedule the first user terminal for data transmission in 
the first transmission interval with the first spatial multiplexing mode and to schedule 
the second user terminal for data transmission in the second transmission interval with 
the second spatial multiplexing mode. 

28. The apparatus of claim 27, wherein the first spatial multiplexing mode is 
a steered spatial multiplexing mode and the second spatial multiplexing mode is a non- 
steered spatial multiplexing mode. 

29. The apparatus of claim 28, further comprising: 
a transmit spatial processor operative to 

spatially process a first plurality of data streams with a plurality of 
steering vectors to transmit the first plurality of data streams on orthogonal 
spatial channels of a MEMO channel for the first user terminal, and 

provide a second plurality of data streams for transmission from a 
plurality of antennas to the second user terminal. 

30. The apparatus of claim 28, further comprising: 
a receive spatial processor operative to 

perform receiver spatial processing on a first plurality of received symbol 
streams with a plurality of eigenvectors to obtain estimates of a first plurality of 
data streams transmitted by the first user terminal, and 

perform receiver spatial processing on a second plurality of received 
symbol streams in accordance with a spatial filter to obtain estimates of a second 
plurality of data streams transmitted by the second user terminal. 
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31. An apparatus in a wireless multiple-access multiple-input multiple- 
output (MIMO) communication system, comprising: 

means for selecting a first user terminal for data transmission in a first 
transmission interval; 

means for selecting a first spatial multiplexing mode to use for the first user 
terminal; 

means for selecting a second user terminal for data transmission in a second 
transmission interval; 

means for selecting a second spatial multiplexing mode to use for the second 
user terminal; 

means for scheduling the first user terminal for data transmission in the first 
transmission interval with the first spatial multiplexing mode; and 

means for scheduling the second user terminal for data transmission in the 
second transmission interval with the second spatial multiplexing mode. 

» 

32. The apparatus of claim 31, wherein the first spatial multiplexing mode is 
a steered spatial multiplexing mode and the second spatial multiplexing mode is a non- 
Steered spatial multiplexing mode. 

33. The apparatus of claim 32, further comprising: 

means for spatially processing a first plurality of data streams with a plurality of 
steering vectors to transmit the first plurality of data streams on orthogonal spatial 
channels of a MIMO channel for the first user terminal; and 

means for providing a second plurality of data streams for transmission from a 
plurality of antennas to the second user terminal. 

34. The apparatus of claim 32, further comprising: 

means for performing receiver spatial processing on a first plurality of received 
symbol streams with a plurality of eigenvectors to obtain estimates of a first plurality of 
data streams transmitted by the first user terminal; and 
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means for performing receiver spatial processing on a second plurality of 
received symbol streams in accordance with a spatial filter to obtain estimates of a 
second plurality of data streams transmitted by the second user terminal. 

35. A method of transmitting data in a wireless multiple-input multiple- 
output (MMO) communication system, comprising: 

coding and modulating a first plurality of data streams to obtain a first plurality 
of data symbol streams; 

spatially processing the first plurality of data symbol streams with a first 
plurality of steering vectors to obtain a first plurality of transmit symbol streams for 
transmission from a plurality of antennas to a first user terminal in a first transmission 
interval; 

coding and modulating a second plurality of data streams to obtain a second 
plurality of data symbol streams; and 

providing the second plurality of data symbol streams as a second plurality of 
transmit symbol streams for transmission from the plurality of antennas to a second user 
terminal in a second transmission interval. 

36. The method of claim 35, further comprising: 

deriving the first plurality of steering vectors such that the first plurality of data 
streams are transmitted on a plurality of orthogonal spatial channels of a first MEMO 
channel for the first user terminal. 

37. The method of claim 35, further comprising: 

coding and modulating a third plurality of data streams to obtain a third plurality 
of data symbol streams; and 

spatially processing the third plurality of data symbol streams with a second 
plurality of steering vectors to obtain a third plurality of transmit symbol streams for 
transmission from the plurality of antennas to a plurality of user terminals in a third 
transmission interval. 
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38. The method of claim 37, further comprising: 

deriving the second plurality of steering vectors such that the third plurality of 
data streams are received with suppressed crosstalk at the plurality of user terminals. 

39. An apparatus in a wireless multiple-input multiple-output (MIMO) 
communication system, comprising: 

a transmit data processor operative to 

code and modulate a first plurality of data streams to obtain a first plurality 
of data symbol streams, and 

code and modulate a second plurality of data streams to obtain a second 
plurality of data symbol streams; and 

a transmit spatial processor operative to 

spatially process the first plurality of data symbol streams with a first 
plurality of steering vectors to obtain a first plurality of transmit symbol streams for 
transmission from a plurality of antennas to a first user terminal in a first transmission 
interval, and 

provide the second plurality of data symbol streams as a second plurality of 
transmit symbol streams for transmission from the plurality of antennas to a second user 
terminal in a second transmission interval. 

40. A method of receiving data in a wireless multiple-input multiple-output 
(MIMO) communication system, comprising: 

performing receiver spatial processing on a first plurality of received symbol 
streams in accordance with a first spatial multiplexing mode to obtain a first plurality of 
recovered data symbol streams; 

demodulating and decoding the first plurality of recovered data symbol streams 
in accordance with a first plurality of rates to obtain a first plurality of decoded data 
streams; 

performing receiver spatial processing on a second plurality of received symbol 
streams in accordance with a second spatial multiplexing mode to obtain a second 
plurality of recovered data symbol streams; and 
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demodulating and decoding the second plurality of recovered data symbol 
streams in accordance with a second plurality of rates to obtain a second plurality of 
decoded data streams. 

41. The method of claim 40, wherein the first spatial multiplexing mode is a 
steered spatial multiplexing mode, and wherein the first plurality of received symbol 
streams are spatially processed with a plurality of eigenvectors for a plurality of spatial 
channels of a MIMO channel for a user terminal. 

42. The method of claim 40, wherein the second spatial multiplexing mode is 
a non-steered spatial multiplexing mode. 

43. The method of claim 42, wherein the second plurality of decoded data 
streams are estimates of a plurality of data streams transmitted by a single user terminal. 

44. The method of claim 42, wherein the second plurality of decoded data 
streams are estimates of a plurality of data streams transmitted simultaneously by a 
plurality of user terminals. 

45. The method of claim 42, wherein the second plurality of received symbol 
streams are spatially processed based on a channel correlation matrix inversion (CCMT) 
technique. 

46. The method of claim 42, wherein the second plurality of received symbol 
streams are spatially processed based on a minimum mean square error (MMSE) 
technique. 

47. The method of claim 42, wherein the second plurality of received symbol 
streams are spatially processed based on a successive interference cancellation (SIC) 
technique. 

48. An apparatus in a wireless multiple-input multiple-output (MIMO) 
communication system, comprising: 
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a receive spatial processor operative to 

perform receiver spatial processing on a first plurality of received symbol 
streams in accordance with a first spatial multiplexing mode to obtain a first plurality of 
recovered data symbol streams, and 

perform receiver spatial processing on a second plurality of received symbol 
streams in accordance with a second spatial multiplexing mode to obtain a second 
plurality of recovered data symbol streams; and 
a receive data processor operative to 

demodulate and decode the first plurality of recovered data symbol streams 
in accordance with a first plurality of rates to obtain a first plurality of decoded data 
streams, and 

demodulate and decode the second plurality of recovered data symbol 
streams in accordance with a second plurality of rates to obtain a second plurality of 
decoded data streams. 

49. A method of transmitting data in a wireless multiple-input multiple- 
output (MMO) communication system, comprising: 

receiving information indicating a spatial multiplexing mode and a plurality of 
rates to use for data transmission, wherein the spatial multiplexing mode is selected 
from among a plurality of spatial multiplexing modes supported by the system, and 
wherein each of the plurality of rates is selected from among a set of rates supported by 
the system; 

coding and modulating a plurality of data streams in accordance with the 
plurality of rates to obtain a plurality of data symbol streams; and 

spatially processing the plurality of data symbol streams in accordance with the 
spatial multiplexing mode to obtain a plurality of transmit symbol streams for 
transmission from a plurality of antennas. 

50. The method of claim 49, wherein the spatial multiplexing mode is a 
steered spatial multiplexing mode, and wherein the plurality of data symbol streams are 
spatially processed with a plurality of steering vectors to transmit the plurality of data 
symbol streams on a plurality of orthogonal spatial channels of a MIMO channel. 
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5 1 . The method of claim 50, further comprising: 

transmitting a steered pilot on each of the plurality of orthogonal spatial 
channels. 

52. The method of claim 49, wherein the spatial multiplexing mode is a non- 
steered spatial multiplexing mode, and wherein the plurality of data symbol streams are 
provided as the plurality of transmit symbol streams. 

53. The method of claim 49, further comprising: 

performing calibration so that uplink channel response is reciprocal of downlink 
channel response. 

54. An apparatus in a wireless multiple-input multiple-output (MIMO) 
communication system, comprising: 

a controller operative to receive information indicating a spatial multiplexing 
mode and a plurality of rates to use for data transmission, wherein the spatial 
multiplexing mode is selected from among a plurality of spatial multiplexing modes 
supported by the system, and wherein each of the plurality of rates is selected from 
among a set of rates supported by the system; 

a transmit data processor operative to code and modulate a plurality of data 
streams in accordance with the plurality of rates to obtain a plurality of data symbol 
streams; and 

a transmit spatial processor operative to spatially process the plurality of data 
symbol streams in accordance with the spatial multiplexing mode to obtain a plurality of 
transmit symbol streams for transmission from a plurality of antennas. 

55. A method of receiving data in a wireless multiple-input multiple-output 
(MIMO) communication system, comprising: 

receiving information indicating a spatial multiplexing mode and at least one 
rate to use for data transmission, wherein the spatial multiplexing mode is selected from 
among a plurality of spatial multiplexing modes supported by the system, and wherein 
each of the at least one rate is selected from among a set of rates supported by the 
system; 
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spatially processing at least one received symbol stream in accordance with the 
spatial multiplexing mode to obtain at least one recovered data symbol stream; and 

demodulating and decoding the at least one recovered data symbol stream in 
accordance with the at least one rate to obtain at least one decoded data stream. 

56. The method of claim 55, wherein the spatial multiplexing mode is a 
steered spatial multiplexing mode, and wherein a plurality of received symbol streams 
are spatially processed with a plurality of eigenvectors for a plurality of spatial channels 
of a MIMO channel to obtain a plurality of recovered data symbol streams. 

57. The method of claim 55, wherein the spatial multiplexing mode is a non- 
steered spatial multiplexing mode. 

58. The method of claim 57, wherein a plurality of received symbol streams 
are spatially processed based on a channel correlation matrix inversion (CCMI) 
technique, a minimum mean square error (MMSE) technique, or a successive 
interference cancellation (SIC) technique to obtain a plurality of recovered data symbol 
streams. 

59. The method of claim 57, wherein one received symbol stream is 
processed with channel gain estimates to obtain one recovered data symbol stream. 

60. An apparatus in a wireless multiple-input multiple-output (MIMO) 
communication system, comprising: 

a controller operative to receive information indicating a spatial multiplexing 
mode and at least one rate to use for data transmission, wherein the spatial multiplexing 
mode is selected from among a plurality of spatial multiplexing modes supported by the 
system, and wherein each of the at least one rate is selected from among a set of rates 
supported by the system; 

a receive spatial processor operative to spatially process at least one received 
symbol stream in accordance with the spatial multiplexing mode to obtain at least one 
recovered data symbol stream; and 
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a receive data processor operative to demodulate and decode the at least one 
recovered data symbol stream in accordance with the at least one rate to obtain at least 
one decoded data stream. 
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